如题,看文档中说前者是阻止事件冒泡,后者是阻止所有被定义handler响应。
那么是否可以这么理解,stopPropagation
是在原生的DOM事件中阻止了事件向后传递,而stopImmediatePropagation
是直接cancel掉了你在jQuery上定义的handler。两者的区别就是,一个在DOM上stop,一个在jQuery里stop?那么stopPropagation
岂不是就把stopImmediatePropagation
的功能包括了,还需要设计后者干嘛?
如题,看文档中说前者是阻止事件冒泡,后者是阻止所有被定义handler响应。
那么是否可以这么理解,stopPropagation
是在原生的DOM事件中阻止了事件向后传递,而stopImmediatePropagation
是直接cancel掉了你在jQuery上定义的handler。两者的区别就是,一个在DOM上stop,一个在jQuery里stop?那么stopPropagation
岂不是就把stopImmediatePropagation
的功能包括了,还需要设计后者干嘛?
8 回答4.6k 阅读✓ 已解决
6 回答3.3k 阅读✓ 已解决
5 回答2.8k 阅读✓ 已解决
5 回答6.3k 阅读✓ 已解决
4 回答2.2k 阅读✓ 已解决
4 回答2.7k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
请看文档里对
event.stopImmediatePropagation()
的描述:从这里可以看出,stopImmediatePropagation做了两件事情:
第一件事:阻止 绑定在事件触发元素的 其他同类事件的callback的运行,看他下面的例子就很明白:
第二件事,阻止事件传播到父元素,这跟
stopPropagation
的作用是一样的。所以文档里面还有这么一句话:
意思是说其实这个方法是调用了
stopPropagation()
方法的。stopImmediatePropagation比stopPropagation多做了第一件事情,这就是他们之间的区别