這篇文章主要介紹了javascript實現禁止滑鼠滾輪事件的相關資料,需要的朋友可以參考下
平常我們相容什麼東西總是在調整低版IE的相容性,但這回不是因為低版瀏覽器不給力。而是因為火狐給力過頭了,完全不顧其它瀏覽器的感受標新立異了。除了火狐之外,所有的瀏覽器都可以使用MouseWheel事件來處理滑鼠滾輪的回應。但火狐卻偏偏不支援MouseWheel,使用無厘頭的DOMMouseScroll,這玩意兒除了火狐以外其它瀏覽器都不相容。也就是說,對於滑鼠滾輪事件的處理,火狐只能使用DOMMouseScroll。而非火狐則只能使用MouseWheel。這兩種事件實現的原理不同,他們處理的資料也不同。
- varfirefox=navigator.userAgent.indexOf('Firefox')!=-1;
- firefox?img.addEventListener('DOMMouseScroll',MouseWheel,false):
- (img.onmousewheel=MouseWheel);
- functionMouseWheel(e){
- e=e||window.event;
- if(e.stopPropagation)e.stopPropagation();
- elsee.cancelBubble=true;
- if(e.preventDefault)e.preventDefault();
- elsee.returnValue=false;
- }
我們來看個完整的程式碼
- <!DOCTYPEhtml>
- <style>
- span{font:14px/20px微軟雅黑;}
- #counter{
- width:50px;height:20px;
- border:1pxsolid#CCC;
- background:#F9F9F9;
- font:14px/20pxConsolas;
- text-align:center;
- margin:10px;
- }
- </style>
- <span>使用滑鼠滾輪調整數值大小</span><br/>
- <divid=counter>0</div>
- <script>
- //判斷瀏覽器
- varisIE=navigator.userAgent.match(/MSIE(/d)/i);
- isIE=isIE?isIE[1]:undefined;
- varisFF=/FireFox/i.test(navigator.userAgent);
- //取得元素
- varcounter=document.getElementById(counter);
- //滑鼠滾輪事件
- if(isIE<9)//傳統瀏覽器使用MouseWheel事件
- counter.attachEvent(onmousewheel,function(){
- //計算滑鼠滾輪滾動的距離
- //一格3行,每行40像素,所以除以120
- varv=event.wheelDelta/120;
- counter.innerHTML=counter.innerHTML*1+v;
- //阻止瀏覽器預設方法
- returnfalse;
- });
- elseif(!isFF)//除火狐以外的現代瀏覽器也使用MouseWheel事件
- counter.addEventListener(mousewheel,function(e){
- //計算滑鼠滾輪滾動的距離
- varv=e.wheelDelta/120;
- counter.innerHTML=counter.innerHTML*1+v;
- //阻止瀏覽器預設方法
- e.preventDefault();
- },false);
- else//奇葩的火狐使用DOMMouseScroll事件
- counter.addEventListener(DOMMouseScroll,function(e){
- //計算滑鼠滾輪滾動的距離
- //一格是3行,但是要注意,這裡和像素不同的是它是負值
- varv=-e.detail/3;
- counter.innerHTML=counter.innerHTML*1+v;
- //阻止瀏覽器預設方法
- e.preventDefault();
- },false);
- </script>
以上所述就是本文的全部內容了,希望大家能夠喜歡。