监听鼠标上下滚动事件

js如何判断滚轮的上下滚动,我们应该都见到过这种效果,用鼠标滚轮实现某个表单内的数字向上滚动就增加,向下滚动就减少的操作,这种效果是通过 js对鼠标滚轮的事件监听来实现的。今天简单的研究了一下如何使用javascript来判断鼠标是向上滚动还是向下滚动,简要分享。

首先,不得不说一下,因为不同的浏览器有 不同的滚轮事件。主要是有两种,onmousewheel(firefox不支持)和DOMMouseScroll(只有firefox支持),关于这两 个事件这里不做详述,想要了解的朋友请移步:鼠标滚轮(mousewheel)和DOMMouseScroll事件,所以在这个过程中需要添加事件监听, 代码如下:兼容firefox采用addEventListener监听。

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

另外判断滚轮向上或向下滚动在浏览器中也要考虑兼容性,现在五大浏览器(IE、Opera、 Safari、Firefox、Chrome)中Firefox 使用detail,其余四类使用wheelDelta;两者只在取值上不一致,代表含义却是一致的,detail只取±3,wheelDelta只 取±120,其中正数表示为向上,负数表示向下。
 
具体的示例代码如下所示:

  1. <label for="wheelDelta">滚动值:</label>(IE/Opera)<input type="text" id="wheelDelta"/> 
  2. <label for="detail">滚动值:(Firefox)</label><input type="text" id="detail"/> 
  3. <script type="text/javascript"
  4. var scrollFunc=function(e){ 
  5.     ee=e || window.event; 
  6.     var t1=document.getElementById("wheelDelta"); 
  7.     var t2=document.getElementById("detail"); 
  8.     if(e.wheelDelta){//IE/Opera/Chrome 
  9.         t1.value=e.wheelDelta; 
  10.     }else if(e.detail){//Firefox 
  11.         t2.value=e.detail; 
  12.     } 
  13. /*注册事件*/ 
  14. if(document.addEventListener){ 
  15.     document.addEventListener('DOMMouseScroll',scrollFunc,false); 
  16. }//W3C 
  17. window.onmousewheel=document.onmousewheel=scrollFunc;//IE/Opera/Chrome 
  18. </script

通过运行上述代码我们可以得出以下结果:

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

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

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

转载请注明:代码家园 » JS判断鼠标向上滚动还是向下滚动

转载于:https://www.cnblogs.com/xiaoyunyun/p/4955686.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值