• jquery之冒泡事件介绍以及阻止冒泡


    什么是事件冒泡

    <div style=" 200px;height: 200px;background: red;margin: 200px auto;" onclick="box()">
        <p onclick="test()" style="background: blue">
            wubin.pro <br>
            <span style="background: green" onclick="inner()">子钦博客</span>
        </p>
    </div>
    <script>
        function inner() {
            alert('inner');
        }
        function test() {
            alert('test')
        }
        function box() {
            alert('box')
        }
    </script>

    布局结构如下图

    一共单层元素

    从外到里依次:div、p、span

    每个元素都有单机事件

    当单击div触发弹出box

    当单击p标签时依次弹出:test、box

    当单击span标签依次弹出:inner、test、box

    这个即为事件冒泡

    从最里层冒泡到最外层

    如何阻止

    很多时候我们不希望事件冒泡

    也就是我点击p的时候只弹出test

    点击span时候只弹出inner

    1.event.stopPropagation()

    <body>
        <div style=" 200px;height: 200px;background: red;margin: 200px auto;" onclick="box()">
            <p onclick="test()" style="background: blue">
                wubin.pro <br>
                <span style="background: green" onclick="inner(event)">武斌博客</span>
            </p>
        </div>
        <script>
            function inner() {
                alert('inner');
                event.stopPropagation();
            }
            function test() {
                alert('test')
            }
            function box(event) {
                alert('box')
            }
        </script>
    </body>
    

    这个时候再点击子钦博客时

    只是弹出inner    
    2.return false

      

    <div style=" 200px;height: 200px;background: red;margin: 200px auto;" >
        <p  style="background: blue">
            wubin.pro <br>
            <span style="background: green" >武斌博客</span>
        </p>
    </div>
    <script>
        $(function () {
            $('span').click(function(){
                alert('inner');
                return false;
            })
            $('p').click(function(){
                alert('test');
            })
            $('div').click(function(){
                alert('box');
            })
        })
    </script>

    效果跟第一种相同

    都可以阻止事件冒泡

    return false与event.stopPropagation()区别

    我们将以上代码修改为:

     

    <div style=" 200px;height: 200px;background: red;margin: 200px auto;" >
        <p  style="background: blue">
            wubin.pro <br>
            <a href="https://wubin.pro" style="background: green" >子钦博客</a>
        </p>
    </div>
    <script>
        $(function () {
            $('a').click(function(event){
                alert('inner');
                // return false;
                event.stopPropagation();
            })
            $('p').click(function(){
                alert('test');
            })
            $('div').click(function(){
                alert('box');
            })
        })
    </script> 

    可以看出

    当使用return false时

    a标签的默认行(跳转页面)为也会被阻止

    当使用event.stopPropagation()时

    先弹出inner

    然后页面跳转

    总结

     

    <div style=" 200px;height: 200px;background: red;margin: 200px auto;" >
        <p  style="background: blue">
            wubin.pro <br>
            <a href="https://wubin.pro" style="background: green" >子钦博客</a>
        </p>
    </div>
    <script>
        $(function () {
            $('a').click(function(event){
                alert('inner');
                // return false;
                // event.stopPropagation();
                event.preventDefault();
            })
            $('p').click(function(){
                alert('test');
            })
            $('div').click(function(){
                alert('box');
            })
        })
    </script>
    

    return false:阻止事件冒泡和默认行为

    event.stopPropagation():单独阻止事件冒泡

    event.preventDefault():单独阻止默认行为

      

  • 相关阅读:
    (转)ios限制控制器旋转
    iOS NSMutableURLRequest 上传图片
    iOS中UIWebView使用JS交互
    Cocoa pods的安装和使用
    NSThread/NSOperation/GCD 三种多线程技术
    动画效果-基础动画设置(改变大小,改变透明度,翻转,旋转,复原)
    动画效果一风火轮加载效果/动态图展示
    Swift代理和传值
    Swift基础(类,结构体,函数)
    IOS面试问题总结
  • 原文地址:https://www.cnblogs.com/zmdComeOn/p/10609271.html
Copyright © 2020-2023  润新知