鼠标滚动:mousewheel事件在Firefox采用DOMMouseScroll事件的统一处理
2017-04-09 12:50
597 查看
这是一个小事件,但当下的WEB应用交互非常丰富,判断鼠标的滚动来执行相应的操作是比较常见的。我用Chrome/IE/Firefox/Opera 4种浏览器做测试,发现只有firefox的处理方法有很大的不同,下面细说一下这个情况:
为了方便统一处理,我们还得编写一个函数,让firefox与其它浏览器的取值与方向相同,代码如下:
上面采用-event.detail来保持方向一致,放大24倍来保持值一致。(保持一次并非必需的,但有些情况下保持一致有利于处理)
第1、事件的名称不同
其它浏览器均采用mousewheel做为事件的名称,而Firefox采用DOMMouseScroll做为事件的名称,为了兼容,那我们就得绑定两次事件,如下:document.addEventListener('mousewheel', handlerMouseWheel); document.addEventListener('DOMMouseScroll', handlerMouseWheel);
第2、判断滚轮的方向和值均不同
其它浏览器均是向上滚动为正值(+120)、向下滚动为负值(-120)。而Firefox则是向上滚动为负值(-5),向下滚动为正值(+5)。第3、包装event对象不同
Firefox对滚轮滚动的值保存在event对象中的detail属性里,而其它浏览器保存在event对象中的wheelDelta属性。为了方便统一处理,我们还得编写一个函数,让firefox与其它浏览器的取值与方向相同,代码如下:
var getWheelDelta = function(event) { return event.wheelDelta || (-event.detail * 24); }
上面采用-event.detail来保持方向一致,放大24倍来保持值一致。(保持一次并非必需的,但有些情况下保持一致有利于处理)
相关文章推荐
- DOMMouseScroll,onmousewheel 鼠标滚动事件js
- 关于浏览器兼容的问题以及字符串编码的一个坑,鼠标滚动事件mousewheel和DOMMouseScroll
- 鼠标滚轮事件(mousewheel、DOMMouseScroll)
- 鼠标滚轮(mousewheel)和DOMMouseScroll事件 (转载)
- js鼠标滚轮事件(mousewheel/DOMMouseScroll)
- 鼠标滚动事件mousewheel(DOMMouseScroll)
- 鼠标滚动事件onscroll在firefox/chrome/Ie中执行次数的问题处理
- 鼠标滚动事件onscroll在firefox/chrome/Ie中执行次数的问题处理
- 鼠标滑轮事件的差异onmousewheel和DOMMouseScroll
- js鼠标滚轮事件(mousewheel/DOMMouseScroll)
- js处理局部scroll事件禁止外部scroll滚动解决办法,jquery.mousewheel.js处理时禁止办法说明
- mousewheel,DOMMouseScroll判断滚轮滚动方向
- JS 鼠标滚轮事件(mousewheel/DOMMouseScroll)
- 给浏览器绑定鼠标滚动事件(兼容FireFox)
- 鼠标-滚动-Mousewheel-事件
- mousewheel 与 DOMMouseScroll
- JS滚轮事件(mousewheel/DOMMouseScroll)了解
- OL3-Cesium 二三维鼠标事件统一处理
- JS滚轮事件(mousewheel/DOMMouseScroll)了解
- JS滚轮事件(mousewheel/DOMMouseScroll)了解