JS阻止事件的传播行为

好记性不如赖笔头…………

如果用户所点击的一个区域,在另一个区域或多个区域内,且每个区域都有相同的事件,那么触发了一个区域时,就会默认触发它的父区域的事件,这显然不是我们想要,这就可以通过阻止事件传播来实现

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>JS阻止事件的传播</title>
</head>
<body>
    <div onclick="div1();">
        <div onclick="div2(event);">点我试试</div>
    </div>
</body>
<script type="text/javascript">
    function div1(){
        alert("最外层的DIV层");
    }

//  注意: IE浏览器的后面几个版本都 支持了W3C标准,之前有个别版本不支持
//          event在IE不支持的版本中,是无法接收到事件的,并且没有stopProgapation方法
//          火狐、google及最新的IE版本的结束事件都支持stopPropagation()方法来结束默认行为
//          老版本的IE如想结束默认行为,须要使用window.event.cancelBubble = true;方法

    function div2(event){
        alert("最内层的DIV层");
        if(event && event.stopPropagation){
            alert("W3C标准");
            event.stopPropagation();
        }else{
            alert("IE标准");
            window.event.cancelBubble = true;
        }
    }
</script>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值