码迷,mamicode.com
首页 > Web开发 > 详细

Js事件捕获和冒泡

时间:2015-05-19 19:09:05      阅读:241      评论:0      收藏:0      [点我收藏+]

标签:

昨天有个面试官问我的问题,他直接问我两个DIV嵌套,都有click事件,单击的时候先弹出子DIV还是父DIV。完全不知所以然。

过后经过查询资料后,很是惭愧。原来他问的就是关于JS捕获和冒泡的。



我查询了一些资料:

事件捕获(父--》 子)
当你使用事件捕获时,父级元素先触发,子级元素后触发,即div先触发,p后触发。

事件冒泡(子--》 父)
当你使用事件冒泡时,子级元素先触发,父级元素后触发,即p先触发,div后触发。

W3C模型
W3C模型是将两者进行中和,在W3C模型中,任何事件发生时,先从顶层开始进行事件捕获,直到事件触发到达了事件源元素。然后,再从事件源往上进行事件冒泡,直到到达document。


那么程序员能不能自己选择触发哪种事件呢?当然可以。


程序员可以自己选择绑定事件时采用事件捕获还是事件冒泡,方法就是绑定事件时通过addEventListener函数,它有三个参数,第三个参数若是true,则表示采用事件捕获,若是false,则表示采用事件冒泡。

ele.addEventListener(‘click‘,doSomething2,true)

true=捕获

false=冒泡

传统绑定事件方式
在一个支持W3C DOM的浏览器中,像这样一般的绑定事件方式,是采用的事件冒泡方式。

ele.onclick = doSomething2

但是IE浏览器不支持这个addEventListener、也没有三个参数、也不支持事件捕获。但是IE也有一个函数,attachEvent 


ele.attachEvent("onclick", doSomething2);

附:事件冒泡(的过程):事件从发生的目标(event.srcElement||event.target)开始,沿着文档逐层向上冒泡,到document为止。


下边的内容是从其他博客摘过来的,可以借鉴http://blog.csdn.net/xqf309/article/details/8557493 

做个小测试。感受一下冒泡事件。




Js事件捕获和冒泡

标签:

原文地址:http://blog.csdn.net/hejiakuo/article/details/45846881

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!