zoukankan      html  css  js  c++  java
  • jQuery中两种阻止事件冒泡的区别

    方式一:event.stopPropagation();

    方式二:return false;

    但是这两种方式是有区别的。return false 不仅阻止了事件往上冒泡,而且阻止了事件本身。event.stopPropagation() 则只阻止事件往上冒泡,不阻止事件本身。

    例子: 当文本输入框获取焦点后,在div1的mousedown事件中采用 event.stopPropagation(); 代码,我们鼠标单击红色区域后文本输入框光标失去。而当我们使用 return false; 代码时,鼠标单击红色区域光标仍然停留在文本输入框内。

    <!DOCTYPE html>
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
    <script src="jquery-1.12.3.min.js"></script>
    <script>
        $(document).ready(function(){
            $("#div1").mousedown(function(event){
                //event.stopPropagation();
                return false;
            });
            $("#div2").mousedown(function(event){
                alert("trigger mousedown event of rootDiv");
            });
        });
    </script>
    </head>
    <body>
        <div id="rootDiv" style="position:relative;left:400px;top:200px;">
            <div>1.单击输入框,使输入框获取焦点:</div>
            <input id="input1" style="250px;" type="text"></input>
            <div id="div2">
                <div id="div1" style="200px;height:200px;"><br><br>2.然后再单击这里</div>
            </div>
        </div>
    </body>
    </html>

  • 相关阅读:
    跨域常见解决方案
    express-session的简单使用说明
    Spring Cloud中,如何解决Feign/Ribbon第一次请求失败的问题?
    继承父类的静态方法的加载顺序
    sql索引优化
    EXPLAIN 执行计划详解
    JVM总括二-垃圾回收:GC Roots、回收算法、回收器
    dubbo知识体系
    Spring bean的生命流程
    日志体系与异常处理
  • 原文地址:https://www.cnblogs.com/duanlianjiang/p/5532105.html
Copyright © 2011-2022 走看看