网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的考试资料:

 

标题 js冒泡/捕获事件及阻止冒泡方法详细总结
内容
    javascript, jquery的事件中都存在事件冒泡和事件捕获的问题,针对这两个问题,本文给出详细的解决方法,需要的朋友不要错过
    javascript, jquery的事件中都存在事件冒泡和事件捕获的问题,下面将两种问题及其解决方案做详细总结。
    事件冒泡是一个从子节点向祖先节点冒泡的过程;
    事件捕获刚好相反,是从祖先节点到子节点的过程。
    给一个jquery点击事件的例子:
    代码如下:
    <!DOCTYPE html>
    <meta charset="utf-8">
    <title>test</title>
    <head>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
    <script type="text/javascript">
    $(function(){
    $('#clickMe').click(function(){
    alert('hello');
    });
    $('body').click(function(){
    alert('baby');
    });
    });
    </script>
    </head>
    <body>
    <div>
    <button type="button" id="button2">click me</button>
    <button id="clickMe">click</button>
    </div>
    </body>
    </html>
    事件冒泡现象:点击 “id=clickMe” 的button,会先后出现“hello” 和 “baby” 两个弹出框。
    分析:当点击 “id=clickMe” 的button时,触发了绑定在button 和 button 父元素及body的点击事件,所以先后弹出两个框,出现所谓的冒泡现象。
    事件捕获现象:点击没有绑定点击事件的div和 “id=button2” 的button, 都会弹出 “baby” 的对话框。
    在实际的项目中,我们要阻止事件冒泡和事件捕获现象。
    阻止事件冒泡方法:
    法1:当前点击事件中return false;
    代码如下:
    $('#clickMe').click(function(){
    alert('hello');
    return false;
    });
    法2:
    代码如下:
    $('#clickMe').click(function(event){
    alert('hello');
    var e = window.event || event;
    if ( e.stopPropagation ){ //如果提供了事件对象,则这是一个非IE浏览器
    e.stopPropagation();
    }else{
    //兼容IE的方式来取消事件冒泡
    window.event.cancelBubble = true;
    }
    });
随便看

 

在线学习网考试资料包含高考、自考、专升本考试、人事考试、公务员考试、大学生村官考试、特岗教师招聘考试、事业单位招聘考试、企业人才招聘、银行招聘、教师招聘、农村信用社招聘、各类资格证书考试等各类考试资料。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/5/17 11:07:03