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

a.swf被添加到網(wǎng)頁(yè)中, a.swf和html頁(yè)面同時(shí)存在滾動(dòng)條, 項(xiàng)目經(jīng)理提了一個(gè)BT的需求---處理a.swf鼠標(biāo)滾動(dòng)的時(shí)候html頁(yè)面不執(zhí)行滾動(dòng), 反之則執(zhí)行html頁(yè)面的滾動(dòng),遇到此問(wèn)題的朋友可以參考下啊,希望本文對(duì)你有所幫助
我們?cè)谧鲩_(kāi)發(fā)時(shí)經(jīng)常會(huì)遇到這種情況:
a.swf被添加到網(wǎng)頁(yè)中, a.swf和html頁(yè)面同時(shí)存在滾動(dòng)條, 項(xiàng)目經(jīng)理提了一個(gè)BT的需求---處理a.swf鼠標(biāo)滾動(dòng)的時(shí)候html頁(yè)面不執(zhí)行滾動(dòng), 反之則執(zhí)行html頁(yè)面的滾動(dòng)!
應(yīng)該怎么做呢?
方法1:
1.鼠標(biāo)移入a.swf滾動(dòng)區(qū)域的時(shí)候: 告知JS移除瀏覽器鼠標(biāo)滾動(dòng)監(jiān)聽(tīng).
2.鼠標(biāo)移出a.swf滾動(dòng)區(qū)域的時(shí)候: 告知JS添加瀏覽器鼠標(biāo)滾動(dòng)監(jiān)聽(tīng).
3.a.swf的wmode設(shè)置為"window".
總結(jié): wmode設(shè)置為"window"可能會(huì)不滿足項(xiàng)目需求, 這使得a.swf遮擋住任何在其之下的html頁(yè)面; 另外鼠標(biāo)移入a.swf滾動(dòng)區(qū)域后按Alt+Tab切換頁(yè)面時(shí)沒(méi)有告知JS添加瀏覽器鼠標(biāo)滾動(dòng)監(jiān)聽(tīng), 所以在操作之后切回到html頁(yè)面中是沒(méi)有滾動(dòng)處理的
方法2:
1.a.swf取消自身的鼠標(biāo)滾動(dòng)監(jiān)聽(tīng)事件, 添加滾動(dòng)處理接口供JS調(diào)用, 例如wheelToFlash(value).
2.鼠標(biāo)移入a.swf滾動(dòng)區(qū)域的時(shí)候: 告知JS, 例如mouseIsInFlashWheelRange=true.
3.鼠標(biāo)移出a.swf滾動(dòng)區(qū)域的時(shí)候: 告知JS, 例如mouseIsInFlashWheelRange=false;
4.JS監(jiān)聽(tīng)鼠標(biāo)滾動(dòng)事件, 在事件監(jiān)聽(tīng)處理函數(shù)中我們需要做如下判斷
Javascript代碼:
if(mouseIsInFlashWheelRange==true)
{
/**調(diào)用a.swf提供的接口使a.swf模擬滾動(dòng)*/
/**"flash"是html嵌入的a.swf的ID, value為html滾表滾動(dòng)的值*/
document.getElementById("flashID").wheelToFlash(value);
/**阻止html頁(yè)面鼠標(biāo)事件的冒泡, 通常是event.preventDefault()*/
event.preventDefault();
}
else
{
/**處理html正常的滾動(dòng), 我們可以什么都不需要做*/
}
總結(jié): 與方法1相比沒(méi)有了wmode="window"的限制; Alt+Tab的問(wèn)題仍然存在。
注意: 在寫(xiě)JS代碼的時(shí)候我們需要注意兼容性的問(wèn)題, 不同瀏覽器對(duì)鼠標(biāo)事件的監(jiān)聽(tīng)以及滾動(dòng)值的獲取均不相同!
a.swf被添加到網(wǎng)頁(yè)中, a.swf和html頁(yè)面同時(shí)存在滾動(dòng)條, 項(xiàng)目經(jīng)理提了一個(gè)BT的需求---處理a.swf鼠標(biāo)滾動(dòng)的時(shí)候html頁(yè)面不執(zhí)行滾動(dòng), 反之則執(zhí)行html頁(yè)面的滾動(dòng)!
應(yīng)該怎么做呢?
方法1:
1.鼠標(biāo)移入a.swf滾動(dòng)區(qū)域的時(shí)候: 告知JS移除瀏覽器鼠標(biāo)滾動(dòng)監(jiān)聽(tīng).
2.鼠標(biāo)移出a.swf滾動(dòng)區(qū)域的時(shí)候: 告知JS添加瀏覽器鼠標(biāo)滾動(dòng)監(jiān)聽(tīng).
3.a.swf的wmode設(shè)置為"window".
總結(jié): wmode設(shè)置為"window"可能會(huì)不滿足項(xiàng)目需求, 這使得a.swf遮擋住任何在其之下的html頁(yè)面; 另外鼠標(biāo)移入a.swf滾動(dòng)區(qū)域后按Alt+Tab切換頁(yè)面時(shí)沒(méi)有告知JS添加瀏覽器鼠標(biāo)滾動(dòng)監(jiān)聽(tīng), 所以在操作之后切回到html頁(yè)面中是沒(méi)有滾動(dòng)處理的
方法2:
1.a.swf取消自身的鼠標(biāo)滾動(dòng)監(jiān)聽(tīng)事件, 添加滾動(dòng)處理接口供JS調(diào)用, 例如wheelToFlash(value).
2.鼠標(biāo)移入a.swf滾動(dòng)區(qū)域的時(shí)候: 告知JS, 例如mouseIsInFlashWheelRange=true.
3.鼠標(biāo)移出a.swf滾動(dòng)區(qū)域的時(shí)候: 告知JS, 例如mouseIsInFlashWheelRange=false;
4.JS監(jiān)聽(tīng)鼠標(biāo)滾動(dòng)事件, 在事件監(jiān)聽(tīng)處理函數(shù)中我們需要做如下判斷
Javascript代碼:
復(fù)制代碼
代碼如下:if(mouseIsInFlashWheelRange==true)
{
/**調(diào)用a.swf提供的接口使a.swf模擬滾動(dòng)*/
/**"flash"是html嵌入的a.swf的ID, value為html滾表滾動(dòng)的值*/
document.getElementById("flashID").wheelToFlash(value);
/**阻止html頁(yè)面鼠標(biāo)事件的冒泡, 通常是event.preventDefault()*/
event.preventDefault();
}
else
{
/**處理html正常的滾動(dòng), 我們可以什么都不需要做*/
}
總結(jié): 與方法1相比沒(méi)有了wmode="window"的限制; Alt+Tab的問(wèn)題仍然存在。
注意: 在寫(xiě)JS代碼的時(shí)候我們需要注意兼容性的問(wèn)題, 不同瀏覽器對(duì)鼠標(biāo)事件的監(jiān)聽(tīng)以及滾動(dòng)值的獲取均不相同!
相關(guān)文章
html中設(shè)置讓div中的內(nèi)容超出后自動(dòng)顯示滾動(dòng)條
html中如何設(shè)置超出部分自動(dòng)顯示滾動(dòng)條,下面為大家詳細(xì)介紹下讓div中的內(nèi)容超出后自動(dòng)顯示滾動(dòng)條具體實(shí)現(xiàn),感興趣的朋友不要錯(cuò)過(guò)2014-02-18關(guān)于HTML中的滾動(dòng)條/去掉滾動(dòng)條問(wèn)題
本文為大家介紹下關(guān)于HTML中的滾動(dòng)條/去掉滾動(dòng)條問(wèn)題,下面有個(gè)不錯(cuò)的示例,大家可以參考下2014-02-18html讓局部強(qiáng)制出現(xiàn)滾動(dòng)條不破壞整體的樣式和布局
局部出現(xiàn)滾動(dòng)條,這樣就不會(huì)破壞整體的樣式和布局了,下面有個(gè)不錯(cuò)的示例,大家可以拷貝代碼到文本文檔修改文本后綴名,txt 為 .html 預(yù)覽效果2013-10-18- 在網(wǎng)頁(yè)中刪除一些東西的時(shí)候滾動(dòng)條往往還在刪除東西之前的位置,而不是非常不人性化的跑到那一頁(yè)的頂部,那么這是怎么實(shí)現(xiàn)的呢?下面就給大家來(lái)分享一些其他關(guān)于html滾動(dòng)條2013-06-16
html滾動(dòng)條 textarea屬性設(shè)置
本文介紹html滾動(dòng)條 textarea屬性設(shè)置:overflow內(nèi)容溢出時(shí)的設(shè)置,scrollbar-3d-light-color立體滾動(dòng)條亮邊的顏色等等相關(guān)設(shè)置,有需要的朋友可以詳細(xì)參考下,希望對(duì)你們有幫2013-01-04html 滾動(dòng)條在IE6和IE7中兼容性問(wèn)題
具體的表現(xiàn)就是頁(yè)面元素(這里以table為例)的滾動(dòng)條在IE7中正常顯示,在IE6中不顯示。2009-07-25HTML 隱藏滾動(dòng)條和去除滾動(dòng)條的方法
這篇文章主要介紹了HTML 隱藏滾動(dòng)條和去除滾動(dòng)條的方法的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-01