JS鼠标滚轮事件解析

一、不同浏览器的鼠标滚轮事件

首先,不同的浏览器有不同的滚轮事件。主要是有两种,onmousewheelIE/Opera/Chrome支持,firefox不支持)和DOMMouseScroll(只有firefox支持)

另外在操作的过程中需要添加事件监听,兼容性写法

代码如下:

/*注册事件*/
if(document.addEventListener){
    document.addEventListener('DOMMouseScroll',scrollFunc,false); // W3C
}
window.onmousewheel=document.onmousewheel=scrollFunc;             // IE/Opera/Chrome

 

二、通过js事件event对象的返回数值判断滚轮上下

判断滚轮向上或向下在浏览器中也要考虑兼容性,现在五大浏览器(IE、Opera、Safari、Firefox、Chrome)中Firefox 使用detail其余四类使用wheelDelta

两者只在取值上不一致,代表含义一致,detail与wheelDelta只各取两个值,detail只取±3wheelDelta只取±120,其中正数表示为向上,负数表示向下。

代码如下:

<label for="wheelDelta">滚动值:</label>(IE/Opera)<input type="text" id="wheelDelta"/>
<label for="detail">滚动值:(Firefox)</label><input type="text" id="detail"/>
<script type="text/javascript">   var scrollFunc = function(e){   e = e || window.event;   var t1 = document.getElementById("wheelDelta");   var t2 = document.getElementById("detail");   if( e.wheelDelta ){ // IE/Opera/Chrome   t1.value = e.wheelDelta;    }else if( e.detail ){ // Firefox   t2.value = e.detail;   }   }   /*注册事件*/   if(document.addEventListener){   document.addEventListener('DOMMouseScroll',scrollFunc,false); // W3C   }   window.onmousewheel=document.onmousewheel=scrollFunc; // IE/Opera/Chrome </script>

效果如下:

通过运行上述代码我们可以看到:

在非firefox浏览器中,滚轮向上滚动返回的数值是120,向下滚动返回-120。
而在firefox浏览器中,滚轮向上滚动返回的数值是-3,向下滚动返回3

代码部分如下,e.wheelDelta是判断是否为非firefox浏览器e.detail为firefox浏览器

if(e.wheelDelta){   // IE/Opera/Chrome
    t1.value=e.wheelDelta;
}else if(e.detail){ // Firefox
    t2.value=e.detail;
}

 

posted @ 2016-08-09 23:19  奔跑的蜗牛~  阅读(1099)  评论(0编辑  收藏  举报