DOM事件流机制 / 事件捕获
什么是DOM?
DOM 是描述 HTML 的内部数据结构,它会将 Web 页面和 JavaScript 脚本连接起来, 并过滤一些不安全的内容;
HTML 解析器会把字节转换成DOM
一个事件在发生的时候会在子元素和父元素之间传播,这会分成三个阶段:
1. window 传到目标节点 ---- 捕获阶段(上层传到底层)
2. 目标节点触发 ---- 目标阶段
3. 目标节点传到window ---- 冒泡阶段(底层传到上层)
如何阻止冒泡?
1. event.stopPropagation()方法 阻止事件冒泡
$('.btn').click(function (even) {
even.stopPropagation();
alert('按钮被点击了');
})
这是阻止事件的冒泡方法,不让事件向documen上蔓延,但是默认事件任然会执行,当你掉用这个方法的时候,如果点击一个链接,这个链接仍然会被打开。
例如:
<a href="https://www.csdn.net/" class="box">
<button class="btn">按钮</button>
</a>
2. event.preventDefault()方法 阻止默认事件
$('.btn').click(function (even) {
even.preventDefault();
alert('按钮被点击了');
})
这是阻止默认事件的方法,调用此方方法,链接不会被打开,但是会发生冒泡, 冒泡会传递到上一层的父元素;
3. return false;
$('.btn').click(function (even) {
alert('按钮被点击了');
return false;
})
这个方法比较暴力, 他会同时阻止冒泡也会阻止默认事件; 写上这段代码, 链接不会被打开,事件也不会传递到上一层的u父元素; 类似于同时调用了event.stopPropagation()和event.preventDefault()