我們在做開發時經常會遇到這種情況:
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代碼:
複製代碼