JS事件流理解

事件是用户或浏览器自身执行的某种动做,如click,load和mouseover都是事件的名字。html

事件是javaScript和DOM之间的桥梁。java

你若触发,我便执行——事件发生,调用它的处理函数执行相应的JavaScript代码给出响应。浏览器

典型的例子有:页面加载完毕触发load事件;用户单击元素,触发click事件。函数

事件发生时会在元素节点与根节点之间按照特定的顺序传播,路径所通过的全部节点都会收到该事件,这个传播过程即DOM事件流。htm

事件传播的顺序对应浏览器的两种事件流模型:捕获型事件流和冒泡型事件流。对象

冒泡型事件流:事件的传播是从最特定的事件目标到最不特定的事件目标。即从DOM树的叶子到根。seo

捕获型事件流:事件的传播是从最不特定的事件目标到最特定的事件目标。即从DOM树的根到叶子。事件

1)、全部现代浏览器都支持事件冒泡,但在具体实现中略有差异:ip

IE5.5及更早版本中事件冒泡会跳过<html>元素(从body直接跳到document)。class

IE九、Firefox、Chrome、和Safari则将事件一直冒泡到window对象。

2)、IE九、Firefox、Chrome、Opera、和Safari都支持事件捕获。尽管DOM标准要求事件应该从document对象开始传播,但这些浏览器都是从window对象开始捕获事件的。

3)、因为老版本浏览器不支持,不多有人使用事件捕获。建议使用事件冒泡

相关文章
相关标签/搜索