天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

js onmousewheel事件多次觸發問題解決方法

我想做一個首屏和第二屏之間滾動鼠標滾輪就可以整平切換的效果,遇到了很多問題,后來在kk的幫助下,終于解決了這個問題,甚是歡喜,于是記錄一下:

我最初的代碼是這樣的:

<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8" /><style>div {width: 700px;height: 1000px;}.red {background-color: red;}.yellow {background-color: yellow;}</style></head><body><div class="red"> </div><div class="yellow"> </div><div class="red"> </div><div class="yellow"> </div><div class="red"> </div></body><script src="../jQuery/jquery.min.js"></script><script src="test.js"></script></html>
$(document).ready(function(){var height = $(window).height(); //獲取瀏覽器窗口當前可見區域的大小    //鼠標滾動之后整屏切換var scrollFunc = function(e){var scrollTop = document.body.scrollTop || document.documentElement.scrollTop;e = e || window.event;if((e.wheelDelta<0|| e.detail>0) && scrollTop>=0 && scrollTop<height){ //不同瀏覽器向下滾動 $(document.body).animate({scrollTop:height}, "fast");$(document.documentElement).animate({scrollTop:height}, "fast");}else if((e.wheelDelta>0 || e.detail<0) && scrollTop>=height && scrollTop<=height+20){ //不同瀏覽器向上滾動$(document.body).animate({scrollTop:0}, "fast");$(document.documentElement).animate({scrollTop:0}, "fast");}};    //注冊事件if(document.addEventListener){document.addEventListener('DOMMouseScroll',scrollFunc,false);}window.onmousewheel = document.onmousewheel = scrollFunc; //IE、chrome、safira});

這樣的代碼我在IE和火狐下測試都是正常的,但是在谷歌下onmousewheel事件總是會觸發多次,這是一個極其惱人的事情,為什么會多次觸發呢?經過調試,我發現是我們每次滾動鼠標時都是很“兇殘”的一下子滾動很大一個幅度,而不是一小格一小格的慢慢滾動,這就導致了滾動的時候會多次觸發onmousewheel事件,調用scrollFunc函數,在函數內的animate函數沒有執行完的時候還是不斷的被調用,這樣就會出現滾動多次滾動條滾不下來頁滾不上去的情況。于是,我將上面的js代碼改成了下面這樣:

$(document).ready(function(){var height = $(window).height();var scrollFunc = function(e){document.onmousewheel = undefined;var scrollTop = document.body.scrollTop || document.documentElement.scrollTop;e = e || window.event;if((e.wheelDelta<0|| e.detail>0) && scrollTop>=0 && scrollTop<height){ $(document.body).animate({scrollTop:height}, "fast","linear",function(){document.onmousewheel = scrollFunc;});$(document.documentElement).animate({scrollTop:height}, "fast","linear",function(){document.onmousewheel = scrollFunc;});}else if((e.wheelDelta>0 || e.detail<0) && scrollTop>=height && scrollTop<=height+20){$(document.body).animate({scrollTop:0}, "fast","linear",function(){document.onmousewheel = scrollFunc;});$(document.documentElement).animate({scrollTop:0}, "fast","linear",function(){document.onmousewheel = scrollFunc;});}};if(document.addEventListener){document.addEventListener('DOMMouseScroll',scrollFunc,false);}document.onmousewheel = scrollFunc;});

好了,現在的代碼已經能夠正常運行了,不過由于我是一只菜鳥,代碼寫的不夠精致,又被kk說了,在他的提示下,我將冗余的代碼又進行了一番修改:

$(document).ready(function(){var height = $(window).height();var width = $(window).width();var body;if(navigator.userAgent.indexOf("Firefox")>0 || navigator.userAgent.indexOf("MSIE")>0){body = document.documentElement;}else{body = document.body;}var isFinish = true;var scrollFunc = function(e){if(isFinish){var scrollTop = body.scrollTop;e = e || window.event;if((e.wheelDelta<0|| e.detail>0) && scrollTop>=0 && scrollTop<height-20){ scroll(height);}else if((e.wheelDelta>0 || e.detail<0) && scrollTop>=height && scrollTop<=height+20){scroll(0);}}};var scroll = function(height){isFinish = false;$(body).animate({scrollTop:height},"fast","linear",function(){isFinish = true;});};if(navigator.userAgent.indexOf("Firefox")>0){if(document.addEventListener){document.addEventListener('DOMMouseScroll',scrollFunc,false);}}else{document.onmousewheel = scrollFunc;}});

終于得到簡介的代碼了,不得不說,通過解決這個問題,還是學到很多的。以后要向著“write less, do more”的目標更加努力了!!!

如果有哪里寫的不對的,歡迎各位大神們指教,我會虛心學習的。

JavaScript技術js onmousewheel事件多次觸發問題解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 涩涩电影网 | 99RE6这里只有精品国产AV | 魔乳 堕乳漫画acg产卵 | 免费中文字幕视频 | 一本道本线中文无码 | 超碰97人人做人人爱网站 | 亚洲精品久久久久久偷窥 | 爱穿丝袜的麻麻3d漫画免费 | 在线观看插女生免费版 | 18禁无遮挡羞羞污污污污免费 | 中国拍三a级的明星女 | 欧美亚洲高清国产 | 久久精品综合网中文字幕 | 国产欧美一区二区三区免费 | 久久国产欧美日韩精品免费 | 男人把女人桶到高潮嗷嗷叫 | 国产SUV精品一区二区883 | 久久视热频国产这里只有精品23 | 成年人免费观看视频网站 | 国产在线观看成人 | 国产亚洲精品久久7777777 | 9277高清在线观看视频 | 激情内射亚洲一区二区三区 | 国产亚洲精品久久久久久一区二区 | 琪琪see色原网色原网站 | 一级淫片bbbxxx | 快播官方网站 | 蜜臀AV熟女人妻中文字幕 | 青青草色青伊人 | 纯肉高H种马艳遇风流多 | 免费观看成人毛片 | 久久精品一卡二卡三卡四卡视频版 | jizz老太婆| 国内精品偷拍在线观看 | 美女脱光app | 娇妻在床上迎合男人 | 2020国产成人精品免费视频 | 含羞草完整视频在线播放免费 | GAY东北澡堂激情2022 | 爱穿丝袜的麻麻3d漫画免费 | 最近日本MV字幕免费观看在线 |