首页 > 编程 > ASP > 正文

javascript实现禁止鼠标滚轮事件

2024-05-04 11:10:01
字体:
来源:转载
供稿:网友

这篇文章主要介绍了javascript实现禁止鼠标滚轮事件的相关资料,需要的朋友可以参考下

平时我们兼容什么东西总是在调整低版本IE的兼容性,但是这回不是因为低版本浏览器不给力。而是因为火狐给力过头了,完全不顾其它浏览器的感受标新立异了。除了火狐之外,所有的浏览器都可以使用MouseWheel事件来处理鼠标滚轮的响应。但是火狐却偏偏不支持MouseWheel,而使用无厘头的DOMMouseScroll,这玩意儿除了火狐以外其它浏览器都不兼容。也就是说,对于鼠标滚轮事件的处理,火狐只能使用DOMMouseScroll。而非火狐则只能使用MouseWheel。这两种事件实现的原理不同,他们处理的数据也不同。

 

 
  1. var firefox = navigator.userAgent.indexOf('Firefox') != -1; 
  2. firefox ? img.addEventListener('DOMMouseScroll', MouseWheel, false) :  
  3. (img.onmousewheel = MouseWheel); 
  4.  
  5. function MouseWheel(e) { 
  6. e = e || window.event; 
  7.  
  8. if (e.stopPropagation) e.stopPropagation(); 
  9. else e.cancelBubble = true
  10.  
  11. if (e.preventDefault) e.preventDefault(); 
  12. else e.returnValue = false
  13.  

我们来看个完整的代码

 

 
  1. <!DOCTYPE html> 
  2. <style> 
  3. span {font:14px/20px 微软雅黑;} 
  4. #counter { 
  5. width:50px;height:20px; 
  6. border:1px solid #CCC; 
  7. background:#F9F9F9; 
  8. font:14px/20px Consolas; 
  9. text-align:center; 
  10. margin:10px; 
  11. </style> 
  12. <span>使用鼠标滚轮调整数值大小</span><br/> 
  13. <div id="counter">0</div> 
  14. <script> 
  15. //判断浏览器 
  16. var isIE=navigator.userAgent.match(/MSIE (/d)/i); 
  17. isIE=isIE?isIE[1]:undefined; 
  18. var isFF=/FireFox/i.test(navigator.userAgent); 
  19. //获取元素 
  20. var counter=document.getElementById("counter"); 
  21. //鼠标滚轮事件 
  22. if(isIE<9) //传统浏览器使用MouseWheel事件 
  23. counter.attachEvent("onmousewheel",function(){ 
  24. //计算鼠标滚轮滚动的距离 
  25. //一格3行,每行40像素,所以除以120 
  26. var v=event.wheelDelta/120; 
  27. counter.innerHTML=counter.innerHTML*1+v; 
  28. //阻止浏览器默认方法 
  29. return false
  30. }); 
  31. else if(!isFF) //除火狐外的现代浏览器也使用MouseWheel事件 
  32. counter.addEventListener("mousewheel",function(e){ 
  33. //计算鼠标滚轮滚动的距离 
  34. var v=e.wheelDelta/120; 
  35. counter.innerHTML=counter.innerHTML*1+v; 
  36. //阻止浏览器默认方法 
  37. e.preventDefault(); 
  38. },false); 
  39. else //奇葩的火狐使用DOMMouseScroll事件 
  40. counter.addEventListener("DOMMouseScroll",function(e){ 
  41. //计算鼠标滚轮滚动的距离 
  42. //一格是3行,但是要注意,这里和像素不同的是它是负值 
  43. var v=-e.detail/3; 
  44. counter.innerHTML=counter.innerHTML*1+v; 
  45. //阻止浏览器默认方法 
  46. e.preventDefault(); 
  47. },false); 
  48. </script> 

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表