防止滚动冒泡

10

我该如何防止滚动事件冒泡?

以下示例无效:

<!DOCTYPE html> 
<html> 
    <head> 
        <title>Scroll Bubbling</title>
        <style>
            #menu {
                width: 80px;
                height: 150px;
                background: red;
                overflow: auto;
            }
        </style>
        <script type="text/javascript" src="jquery-1.7.2.min.js"></script>
        <script type="text/javascript">
            function isScrollOnBound( scrollContainer ) {
                if ( $( scrollContainer ).scrollTop() === 0 || 
                     $( scrollContainer ).scrollTop() + $( scrollContainer ).innerHeight() >= $( scrollContainer )[0].scrollHeight ) {
                    return true;
                } else {
                    return false;
                }
            }

            $(function() {                  
                $( '#menu' ).on( 'scroll', function(e) {
                    if ( isScrollOnBound( this ) ) {
                        e.stopPropagation();
                    }                   
                });

                $( window ).on( 'scroll', function(e) {
                    alert( 'stopPropagation not working' );
                });                 
            });     
        </script>
    </head> 
    <body>  
        page 1<br />page 2<br />page 3<br />page 4<br />page 5<br />page 6<br />page 7<br />page 8<br />page 9<br />page 10<br />page 11<br />page 12<br />page 13<br />page 14<br />page 15<br />page 16<br />page 17<br />page 18<br />page 19<br />page 20<br />page 21<br />page 22<br />page 23<br />page 24<br />page 25
        <div id="menu">
            menu 1<br />menu 2<br />menu 3<br />menu 4<br />menu 5<br />menu 6<br />menu 7<br />menu 8<br />menu 9<br />menu 10
        </div>
        page 26<br />page 27<br />page 28<br />page 29<br />page 30<br />page 31<br />page 32<br />page 33<br />page 34<br />page 35<br />page 36<br />page 37<br />page 38<br />page 39<br />page 40<br />page 41<br />page 42<br />page 43<br />page 44<br />page 45<br />page 46<br />page 47<br />page 48<br />page 49<br />page 50
    </body>
</html>
3个回答

3
这是需要翻译的内容:

这就是为什么你试图做的事情不起作用。它本来就不应该。

我找到了一个可靠的方法,可以实现你想要的目标(我猜测)。

使用Brandon Aaron的插件

示例 | 代码

var menu = $('#menu')

menu.on('mousewheel', function(e, d) {
    if((this.scrollTop === (menu[0].scrollHeight - menu.height()) && d < 0) || (this.scrollTop === 0 && d > 0)) {
        e.preventDefault();
    }
});

注意:它在IE中也可以工作,只是当JSFiddle包含插件时,IE会返回mime不匹配错误。IE很糟糕。


这个例子在iOS上运行良好,但在Android上无法运行,有任何想法为什么吗? - Diogo Cardoso
@Diogo 不好意思,说实话我对安卓没有太多经验,但我猜测安卓使用了非标准的事件名称,或者该事件不存在。Brandon的插件使用以下内容来附加事件处理程序:DOMMouseScrollmousewheelonmousescroll。在插件的顶部,您可以添加其他要挂钩到处理程序的事件名称。 - ShadowScripter
@Diogo 尽管根据这篇文章DOMMouseScroll应该是能用的。 - ShadowScripter

1

你需要将touchmove绑定到document上(我想是这样),并返回false,表示不做任何事情。只有在需要时(在你的div中滚动时)才绑定它,然后在滚动结束时解除绑定。

我也遇到了父级被滚动而我不想要的问题,这是我唯一能解决它的方法。

当你需要文档不滚动时,请执行以下操作:

$(document).bind('touchmove', function(){
    return false;
});

完成后解除绑定:

$(document).unbind('touchmove');

0
你可以尝试使用setContentHeight()来解决你的问题。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接