0

我正在为网站使用 jQuery jPanelMenu插件。由于导航比较长,我在面板上得到一个滚动条。但是,一旦我到达所述面板的末尾,我也开始滚动正文。有没有办法防止这种情况?

4

1 回答 1

2

由于必须防止父元素滚动,因此必须使用事件 stopPropagation()。

检查 JSFiddle :- JSFiddle

$(document).on('DOMMouseScroll mousewheel','#jPanelMenu-menu', function(ev) {
var $this = $(this),
    scrollTop = this.scrollTop,
    scrollHeight = this.scrollHeight,
    height = $this.height(),
    delta = (ev.type == 'DOMMouseScroll' ?
        ev.originalEvent.detail * -40 :
        ev.originalEvent.wheelDelta),
    up = delta > 0;

var prevent = function() {
    ev.stopPropagation();
    ev.preventDefault();
    ev.returnValue = false;
    return false;
}

if (!up && -delta > scrollHeight - height - scrollTop) {
    $this.scrollTop(scrollHeight);
    return prevent();
} else if (up && delta > scrollTop) {
    $this.scrollTop(0);
    return prevent();
}
});
于 2014-11-13T07:23:54.823 回答