JavaScript 滚轮事件使用说明


  本文标签:JavaScript,滚轮事件

不过遗憾的是各浏览器都不尽相同 。

一) 事件名称不相同
IE, KHTML(Safari, Chrome), Opera对应的事件名称是 "mousewheel" 。而 Gecko(Firefox, Netscape) 对应的事件名称是 "DOMMouseScroll" 。

二) 事件对象的属性不一样
有时我们需要知道用户是向上滚了还是向下滚了 。例如我们有一个响应滚动事件的函数:
复制代码 代码如下:

function wheelHandle(e) {
if(e.wheelDelta) {// IE, KHTML, Opera
alert(e.wheelDelta > 0 ? 向上滚 : 向下滚);
} else { // Gecko
alert(e.detail < 0 ? 向上滚 : 向下滚);
}
}

IE, KHTML 支持 e.wheelDelta ,大于 0 为向上滚动,小于 0 为向下滚动 。Gecko 支持 e.detail,小于 0 为向上滚动,大于 0 为向上滚动,跟前面的相反 。而 Opera 比较牛,两种都支持 。
下面给出一个注册滚轮事件的函数做参考:
复制代码 代码如下:

/**
* 注册滚轮事件函数
* @param element : 注册的事件对象
* @param wheelHandle : 注册事件函数
*/
function addScrollListener(element, wheelHandle) {
if(typeof element != object) return;
if(typeof wheelHandle != function) return;
// 监测浏览器
if(typeof arguments.callee.browser == undefined) {
var user = navigator.userAgent;
var b = {};
b.opera = user.indexOf("Opera") > -1 && typeof window.opera == "object";
b.khtml = (user.indexOf("KHTML") > -1 || user.indexOf("AppleWebKit") > -1 || user.indexOf("Konqueror") > -1) && !b.opera;
b.ie = user.indexOf("MSIE") > -1 && !b.opera;
b.gecko = user.indexOf("Gecko") > -1 && !b.khtml;
arguments.callee.browser = b;
}
if(element == window)
element = document;
if(arguments.callee.browser.ie)
element.attachEvent(onmousewheel, wheelHandle);
else
element.addEventListener(arguments.callee.browser.gecko ? DOMMouseScroll : mousewheel, wheelHandle, false);
}

注册一个监听事件:
复制代码 代码如下:

var display = document.getElementById(display);
function wheelHandle(e) {
if(e.wheelDelta) {// IE, KHTML, Opera
display.innerHTML = (e.wheelDelta > 0 ? 上 : 下);
} else { // Gecko
display.innerHTML = (e.detail < 0 ? 上 : 下);
}
}
addScrollListener(window, wheelHandle);