用户名: 密码: 验证码: 注册           网站地图 高级搜索 RSS订阅 收藏本站
山东十七地市站长联盟信息: 济南 青岛 淄博 枣庄 东营 烟台 潍坊 济宁 泰安 威海 日照 莱芜 临沂 德州 聊城 滨州 菏泽      
您的位置:主页>设计在线>网页设计>

关于DOM事件模型的两件事

[ 来源: | 作者: | 更新日期:2007-11-30 16:15:57 | 评论 0 条 | 我要投稿 ]
  • 事件捕捉(Event Capture)的实现问题
  • IE的高级事件处理模型的问题

一、事件捕捉(Event Capture)的实现问题

字串2

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

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

字串7


(from W3C) 字串8

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

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

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

字串5

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

字串6

  • 当点击#div1(蓝色区域)时,应该会alert出”div1″
  • 当点击#div2(黄色区域)时,应该会先alert出”div1″,再alert出”div2″,因为在事件捕捉阶段,事件是从根元素向下传播的,#div1是#div2的父元素,自然绑定在#div1上的click事件也会先于#div2上的click事件被执行。

然而,以上的设想只试用于Firefox 2和Safari 3 on Windows,在Opera 9中,事情会变成这样: 字串1

  • 当点击#div1(蓝色区域)时,什么都不会发生
  • 当点击#div2(黄色区域)时,会alert出”div1″,随后什么都不会再发生

可以看出,在Opera 9中,目标元素(TargetElement)的click事件没有被执行。通过Realazy(orz…)的指点,找到了这篇文章:《Event capture explained》,发现, 字串7

来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.

字串2

大意是说:DOM规范中陈述了捕捉型的事件不应该在目标元素上被执行,因为捕捉型事件的用意就是为了监测到达目标元素之前的事件。Firefox和Safari的实现都是带有bug的。 字串9

再来看看W3C的DOM Events规范中的原话
A capturing EventListener will not be triggered by events dispatched directly to the EventTarget upon which it is registered.

字串9

所以,在整个事件传播中,被执行的顺序是:

字串6

  1. 父元素中所有的捕捉型事件(如果有)自上而下地执行
  2. 目标元素的冒泡型事件(如果有)
  3. 父元素中所有的冒泡型事件(如果有)自下而上地执行

在了解了这些后,也许还是不要使用事件捕捉为妙,至少暂时不要。 字串9


Tags:模型 事件 关于 捕捉 元素 执行 alert DOM of Opera 目标
您的评论
用户名:新注册) 密码: 匿名评论 [所有评论]

·用户发表意见仅代表其个人意见,并且承担一切因发表内容引起的纠纷和责任
·本站管理人员有权在不通知用户的情况下删除不符合规定的评论信息或留做证据
·请客观的评价您所看到的资讯,提倡就事论事,杜绝漫骂和人身攻击等不文明行为