js如何判断滚轮的上下滚动,咱们应该都见到过这种效果,用鼠标滚轮实现某个表单内的数字向上滚动就增长,向下滚动就减小的操做,这种效果是经过 js对鼠标滚轮的事件监听来实现的。今天简单的研究了一下如何使用javascript来判断鼠标是向上滚动仍是向下滚动,简要分享。javascript
首先,不得不说一下,由于不一样的浏览器有 不一样的滚轮事件。主要是有两种,onmousewheel(firefox不支持)和DOMMouseScroll(只有firefox支持),关于这两 个事件这里不作详述,想要了解的朋友请移步:鼠标滚轮(mousewheel)和DOMMouseScroll事件,因此在这个过程当中须要添加事件监听, 代码以下:兼容firefox采用addEventListener监听。html
- if(document.addEventListener){
- document.addEventListener('DOMMouseScroll',scrollFunc,false);
- }
- window.onmousewheel=document.onmousewheel=scrollFunc;
另外判断滚轮向上或向下滚动在浏览器中也要考虑兼容性,如今五大浏览器(IE、Opera、 Safari、Firefox、Chrome)中Firefox 使用detail,其他四类使用wheelDelta;二者只在取值上不一致,表明含义倒是一致的,detail只取±3,wheelDelta只 取±120,其中正数表示为向上,负数表示向下。
具体的示例代码以下所示:java
- <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){
- ee=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浏览器spa
- if(e.wheelDelta){
- t1.value=e.wheelDelta;
- }else if(e.detail){
- t2.value=e.detail;
- }
转载请注明:代码家园 » JS判断鼠标向上滚动仍是向下滚动firefox