首頁 >web前端 >html教學 >html與內嵌其中的flash均存在捲軸的情況分析與處理方法_HTML/Xhtml_網頁製作

html與內嵌其中的flash均存在捲軸的情況分析與處理方法_HTML/Xhtml_網頁製作

WBOY
WBOY原創
2016-05-16 16:40:341263瀏覽

我們在做開發時經常會遇到這種情況:
a.swf被添加到網頁中, a.swf和html頁面同時存在滾動條, 專案經理提了一個BT的需求---處理a. swf滑鼠滾動的時候html頁面不執行滾動, 反之則執行html頁面的滾動!
應該怎麼做呢?
方法1:
1.滑鼠移入a.swf滾動區域的時候: 告知JS移除瀏覽器滑鼠滾動監聽.
2.滑鼠移出a.swf滾動區域的時候: 告知JS新增瀏覽器滑鼠滾動監聽.
3.a.swf的wmode設定為"window".
總結: wmode設定為"window"可能會不滿足專案需求, 這使得a.swf遮擋住任何在其之下的html頁面; 另外滑鼠移入a.swf捲動區域後按Alt Tab切換頁面時沒有告知JS新增瀏覽器滑鼠滾動監聽, 所以在操作之後切回html頁面中是沒有滾動處理的

方法2:
1.a. swf取消自身的滑鼠滾動監聽事件, 新增滾動處理介面供JS呼叫, 例如wheelToFlash(value).
2.滑鼠移入a.swf滾動區域的時候: 告知JS, 例如mouseIsInFlashWheelRange=true.
3 .滑鼠移出a.swf滾動區域的時候: 告知JS, 例如mouseIsInFlashWheelRange=false;
4.JS監聽滑鼠滾動事件, 在事件監聽處理函數中我們需要做以下判斷
Javascript程式碼:

複製代碼
代碼如下:

if(mouseIsInFlashWheelRange==true)
{
/**呼叫a.swf提供的介面使a.swf模擬滾動*/
/**"flash"是html嵌入的a.swf的ID, value為html滾輪錶滾動的值*/
document.getElementById("flashID").wheelToFlash(value);
/**阻止html頁面滑鼠事件的冒泡, 通常是event.preventDefault()*/ event.preventDefault();
}
else
{
/**處理html正常的滾動, 我們可以什麼都不需要做*/
}

總結
總結總結總結總結總結總總結>: 與方法1相比沒有了wmode="window"的限制; Alt Tab的問題仍然存在。 注意: 在寫JS程式碼的時候我們需要注意相容性的問題, 不同瀏覽器對滑鼠事件的監聽以及滾動值的獲取均不相同!
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn