html與嵌入其中的flash均存在滾動條的情況分析及處理方法
來源:易賢網 閱讀:873 次 日期:2016-06-21 13:52:14
溫馨提示:易賢網小編為您整理了“html與嵌入其中的flash均存在滾動條的情況分析及處理方法”,方便廣大網友查閱!

a.swf被添加到網頁中, a.swf和html頁面同時存在滾動條, 項目經理提了一個BT的需求---處理a.swf鼠標滾動的時候html頁面不執行滾動, 反之則執行html頁面的滾動,遇到此問題的朋友可以參考下啊,希望本文對你有所幫助

我們在做開發時經常會遇到這種情況:

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代碼的時候我們需要注意兼容性的問題, 不同瀏覽器對鼠標事件的監聽以及滾動值的獲取均不相同!

更多信息請查看網頁制作
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
未满十八18勿进黄网站免费看