html與嵌入其中的flash均存在滾動條的情況分析及處理方法
發(fā)布時間:2013-01-23 15:31:57 作者:佚名
我要評論

a.swf被添加到網頁中, a.swf和html頁面同時存在滾動條, 項目經理提了一個BT的需求---處理a.swf鼠標滾動的時候html頁面不執(zhí)行滾動, 反之則執(zhí)行html頁面的滾動,遇到此問題的朋友可以參考下啊,希望本文對你有所幫助
我們在做開發(fā)時經常會遇到這種情況:
a.swf被添加到網頁中, a.swf和html頁面同時存在滾動條, 項目經理提了一個BT的需求---處理a.swf鼠標滾動的時候html頁面不執(zhí)行滾動, 反之則執(zhí)行html頁面的滾動!
應該怎么做呢?
方法1:
1.鼠標移入a.swf滾動區(qū)域的時候: 告知JS移除瀏覽器鼠標滾動監(jiān)聽.
2.鼠標移出a.swf滾動區(qū)域的時候: 告知JS添加瀏覽器鼠標滾動監(jiān)聽.
3.a.swf的wmode設置為"window".
總結: wmode設置為"window"可能會不滿足項目需求, 這使得a.swf遮擋住任何在其之下的html頁面; 另外鼠標移入a.swf滾動區(qū)域后按Alt+Tab切換頁面時沒有告知JS添加瀏覽器鼠標滾動監(jiān)聽, 所以在操作之后切回到html頁面中是沒有滾動處理的
方法2:
1.a.swf取消自身的鼠標滾動監(jiān)聽事件, 添加滾動處理接口供JS調用, 例如wheelToFlash(value).
2.鼠標移入a.swf滾動區(qū)域的時候: 告知JS, 例如mouseIsInFlashWheelRange=true.
3.鼠標移出a.swf滾動區(qū)域的時候: 告知JS, 例如mouseIsInFlashWheelRange=false;
4.JS監(jiān)聽鼠標滾動事件, 在事件監(jiān)聽處理函數中我們需要做如下判斷
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代碼的時候我們需要注意兼容性的問題, 不同瀏覽器對鼠標事件的監(jiān)聽以及滾動值的獲取均不相同!
a.swf被添加到網頁中, a.swf和html頁面同時存在滾動條, 項目經理提了一個BT的需求---處理a.swf鼠標滾動的時候html頁面不執(zhí)行滾動, 反之則執(zhí)行html頁面的滾動!
應該怎么做呢?
方法1:
1.鼠標移入a.swf滾動區(qū)域的時候: 告知JS移除瀏覽器鼠標滾動監(jiān)聽.
2.鼠標移出a.swf滾動區(qū)域的時候: 告知JS添加瀏覽器鼠標滾動監(jiān)聽.
3.a.swf的wmode設置為"window".
總結: wmode設置為"window"可能會不滿足項目需求, 這使得a.swf遮擋住任何在其之下的html頁面; 另外鼠標移入a.swf滾動區(qū)域后按Alt+Tab切換頁面時沒有告知JS添加瀏覽器鼠標滾動監(jiān)聽, 所以在操作之后切回到html頁面中是沒有滾動處理的
方法2:
1.a.swf取消自身的鼠標滾動監(jiān)聽事件, 添加滾動處理接口供JS調用, 例如wheelToFlash(value).
2.鼠標移入a.swf滾動區(qū)域的時候: 告知JS, 例如mouseIsInFlashWheelRange=true.
3.鼠標移出a.swf滾動區(qū)域的時候: 告知JS, 例如mouseIsInFlashWheelRange=false;
4.JS監(jiān)聽鼠標滾動事件, 在事件監(jiān)聽處理函數中我們需要做如下判斷
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代碼的時候我們需要注意兼容性的問題, 不同瀏覽器對鼠標事件的監(jiān)聽以及滾動值的獲取均不相同!
相關文章
- html中如何設置超出部分自動顯示滾動條,下面為大家詳細介紹下讓div中的內容超出后自動顯示滾動條具體實現,感興趣的朋友不要錯過2014-02-18
- 本文為大家介紹下關于HTML中的滾動條/去掉滾動條問題,下面有個不錯的示例,大家可以參考下2014-02-18
- 局部出現滾動條,這樣就不會破壞整體的樣式和布局了,下面有個不錯的示例,大家可以拷貝代碼到文本文檔修改文本后綴名,txt 為 .html 預覽效果2013-10-18
- 在網頁中刪除一些東西的時候滾動條往往還在刪除東西之前的位置,而不是非常不人性化的跑到那一頁的頂部,那么這是怎么實現的呢?下面就給大家來分享一些其他關于html滾動條2013-06-16
- 本文介紹html滾動條 textarea屬性設置:overflow內容溢出時的設置,scrollbar-3d-light-color立體滾動條亮邊的顏色等等相關設置,有需要的朋友可以詳細參考下,希望對你們有幫2013-01-04
- 具體的表現就是頁面元素(這里以table為例)的滾動條在IE7中正常顯示,在IE6中不顯示。2009-07-25
- 這篇文章主要介紹了HTML 隱藏滾動條和去除滾動條的方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-07-01