Home » JavaScript » JavaScript 滚轮事件

JavaScript 滚轮事件

用过 Google 地图的人可能都很熟悉,通过滚动滚轮可以对地图进行缩放,非常地方便。适当地使用滚轮事件可以带来不错的用户体验。
不过遗憾的是各浏览器都不尽相同。

一) 事件名称不相同

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);
2009.06 16

If you enjoyed reading, you can bookmarking and sharing its on your favorite sites.

声明:本文采用Creative Commons License进行许可。转载请注明出自: JavaScript 滚轮事件

5 Comments

  • janwen

    2009年09月4日 11:48 上午

    那怎么才能直接在鼠标滚动的时候定义在这个事件啊

  • CSSBaby

    2009年09月4日 1:28 下午

    文章已经更新,你可以直接使用我给出的函数。

  • walkingp

    2010年02月1日 11:30 上午

    好像Chrome在这方面也不一样,有考虑吗?

  • Amy

    2010年06月6日 1:09 下午

    好像Chrome在这方面也不一样,有考虑吗?

  • CSSBaby

    2010年06月6日 4:49 下午

    @Amy

    有考虑,就是文章中 KHTML。

Leave a Comment :

:) :D :( :o 8O :? 8) :x :P :| ;) :lol: :oops: :cry: :evil: :twisted: :roll: :!: :?: :idea: :arrow: :mrgreen:

You can use these tags:
  1. <a href="" title="">
  2. <abbr title="">
  3. <acronym title="">
  4. <b>
  5. <blockquote cite="">
  6. <cite>
  7. <code>
  8. <del datetime="">
  9. <em>
  10. <i>
  11. <q cite="">
  12. <strike>
  13. <strong>

Recent Comments

  • HHTecShare

    HHTecShare

    @HHTecShar»

  • HHTecShare

    HHTecShare

    其实,把元素换成就不»

  • justjavac

    justjavac

    »

  • CSSBaby

    CSSBaby

    @文行天下 谢»

  • 文行天下

    文行天下

    这个网站的主题真不错»