关于冒泡和阻止默认事件的一个问题

 <a href="https:www.baidu.com"><p>hello</p></a>
var p = document.querySelector('p');
var a = document.querySelector('a');
p.addEventListener('click', function(e) {
    e.stopPropagation();            
},false)
a.addEventListener('click',function(e){
    e.preventDefault();       
},false)

按照代码:

p在a的内部,p的点击事件阻止了事件冒泡,那么a应该不会跳转;

退一万步,p就算没有阻止冒泡,a本身点击事件阻止了默认事件,应该不会跳转。

结果是:a跳转了!!!why???

-----------------------------------------------------------这里是7月31号补充的分界线------------------------------------------------------------------

之前提出这个问题太傻了,今天再看的时候突然想通了。

p的click事件处理器里面阻止了事件冒泡,那么a的click事件处理器就不会被触发,当然a的默认事件就不会被阻止

这样写,a标签点击时就不会跳转

<a href="https:www.baidu.com"><p>hello</p></a>
var a = document.querySelector('a'); 
a.addEventListener('click', function (e) {
    console.log(e.eventPhrase)
    e.preventDefault();
}, false)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值