上海网站建设上海网页设计上海网站制作上海网页制作
 联系电话:021-65584479    13818762608  | 上海网站建设公司 
公司介绍

上海网站建设公司,为您提供专业的网站建设策划营销服务,让您拥有一个高性价比的网站,是我们的目标”。

网站建设流程 网页设计知识 网站案例评析 网站建设资费 建站售后服务 网站制作联系

当前位置网站设计知识 >> 关于DOM事件模型的两件事

关于DOM事件模型的两件事

事件捕捉(Event Capture)的实现问题
IE的高级事件处理模型的问题
一、事件捕捉(Event Capture)的实现问题

首先在说这件事前,先感谢一下Realazy。

W3C DOM Level2的事件模型规范中,事件在DOM树中的传播过程(从根节点到目标节点)被分为了两个阶段:捕捉(Capture)和冒泡(Bubbling)。下面这个图能大概的说明整个过程:


(from W3C)

如果想创建一个捕捉事件,在支持W3C 事件模型的浏览器中,将addEventListener的第三个参数设为true就好了。例如:

document.getElementById('foo').addEventListener('click',function(){alert('Hello, world!');},true);

前一阵因为想弄懂事件捕捉,所以做了点小实验,分别在Firefox 2、Safari 3 on Windows和Opera 9上实践了事件捕捉(当然,因为IE不支持事件捕捉,所以…),实验的原理见下图:

 

ID为div1和div2的两个元素都被委派了捕捉阶段的事件处理函数,这样:

当点击#div1(蓝色区域)时,应该会alert出”div1″
当点击#div2(黄色区域)时,应该会先alert出”div1″,再alert出”div2″,因为在事件捕捉阶段,事件是从根元素向下传播的,#div1是#div2的父元素,自然绑定在#div1上的click事件也会先于#div2上的click事件被执行。
然而,以上的设想只试用于Firefox 2和Safari 3 on Windows,在Opera 9中,事情会变成这样:

当点击#div1(蓝色区域)时,什么都不会发生
当点击#div2(黄色区域)时,会alert出”div1″,随后什么都不会再发生
可以看出,在Opera 9中,目标元素(TargetElement)的click事件没有被执行。通过Realazy(orz…)的指点,找到了这篇文章:《Event capture explained》,发现,

来Opera中的实现才是正确的。此文中有一段话如是说:
The DOM spec states that capturing events should not fire on target, because the idea of a capturing event is to detect events before they reach their targets. Because of bugs in Gecko and Safari, web content that is tested mostly with Firefox or other Gecko-based browsers sometimes expects capturing listeners to fire on target. Such content will fail in Opera 7, 8 and current releases of 9 because of its correct implementation of the standard
22:43 2008-5-26

[来源:上海网站建设] [作者:上海网站建设] [日期:08-05-26] [热度:]

评论

发表评论

友情链接