0

我有一个模板,当用户使用鼠标滚轮时,模板会水平滚动。

但它只适用于 chrome 。

有什么方法可以在 Firefox 和 IE 中水平滚动?

这是一个演示:http: //jsfiddle.net/VhERd/

和jQuery:

<script>
    $(function() {

       $("body").mousewheel(function(event, delta) {

          this.scrollLeft -= (delta * 30);

          event.preventDefault();

       });

    });
</script>
    <script src="http://css-tricks.com/examples/HorzScrolling/jquery.mousewheel.js"></script>

最后为我的英语道歉;)

4

2 回答 2

2

它需要处理html元素,而不是bodyFirefox 的元素。

$("body, html").mousewheel....
于 2013-09-13T17:25:29.640 回答
1

我已经使用了这个功能,它有点hacky,但可以完成工作。

function scrollPage (e) {
    var delta = e.deltaX || e.wheelDelta,
        dir = (delta > 0) ? -90 : 90;
    if (window.addEventListener && !(window.chrome || window.opera)) {
        dir *= -1;
    }
    window.scrollBy(dir, 0);
    e.returnValue = false;
    if (e.preventDefault) {
        e.preventDefault();
    }
    return false;
}

并附上事件:

if (window.addEventListener && (!window.chrome && !window.opera)) {
    window.addEventListener('wheel', scrollPage, false); // IE9+, FF
} else if (window.chrome || window.opera) {
    window.addEventListener('mousewheel', scrollPage, false); // Chrome & Opera
} else {
    document.attachEvent('onmousewheel', scrollPage); // IE8-
}

jsFiddle 的现场演示

于 2013-09-13T17:24:49.213 回答