• 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():单独阻止默认行为

      

  • 相关阅读:
    性能测试时如何确认并发用户数
    web测试误区:浏览器后退键退出系统会话失效
    读书笔记(一)
    Loadrunner参数化数据配置与更新方式
    常见软件测试类型及特点
    Loadrunner录制脚本与编写脚本的区别
    软件测试常见文档要点及区别
    APP测试之Monkey测试
    Python操作Redis大全
    【IntelliJ IDEA】在idea上操作 git分支合并【如何将远程swagger分支 合并到 远程 master分支上】【如何切换 本地分支】
  • 原文地址:https://www.cnblogs.com/zmdComeOn/p/10609271.html
Copyright © 2020-2023  润新知