W3C DOM 事件模型(简述)
1、事件模型
由于事件捕获与冒泡模型都有其长处和解释,DOM标准支持捕获型与冒泡型,能够说是它们两者的结合体。它能够在一个DOM元素上绑定多个事件处理器,而且在处理函数内部,thiskeyword仍然指向被绑定的DOM元素,另外处理函数參数列表的第一个位置传递事件event对象。首先是捕获式传递事件,接着是冒泡式传递,所以,假设一个处理函数既注冊了捕获型事件的监听,又注冊冒泡型事件监听,那么在DOM事件模型中它就会被调用两次。
 【 oschina】
【 oschina】
2、事件传播
A)冒泡模式(Bubble)IE浏览器仅仅支持这样的形式的传播,即事件对象从事件触发的目标(target)開始,一直传播到侦听相同事件类型的target祖先结点为止。即作为全局变量的时间对象沿着”元素树“向上传播
B)捕捉模式(Capture)这样的模式与冒泡模式正好相反,即事件对象是从目标的外层向目标传播的,即从树的根结点向叶子结点传播。
3、事件注冊
依据 DOM 2 Events 中描写叙述,节点使用 'addEventListener' 和 'removeEventListener' 方法绑定和解绑事件监听器。
if(add.addEventListener){
    add.addEventListener("click",showMsgB,false);
    remove.addEventListener("click",removeE,false);
}
IE下没有addEventListener,可是也有自己的attachEvent,即所谓的Microsoft Model。二者的实现基本同样仅仅是attachEvent的第一个參数(事件类型)须要加”on”,而addEventListener不用,另外attachEvent由于不支持事件捕捉,所以也没有第三个參数。
if(add.attachEvent){
    add.attachEvent("onclick",showMsgA);
    remove.attachEvent("onclick",removeE);
}
在支持W3C DOM的浏览器中,传统的事件注冊被看作是注冊于冒泡阶段。element.onEvent =handler()
4、stopPropagation, preventDefault 和 return false 的差别
stopPropagation():由于事件能够在各层级的节点中传递, 无论是冒泡还是捕获, 有时我们希望事件在特定节点运行完之后不再传递, 能够使用事件对象的 stopPropagation() 方法。
preventDefault() 阻止后面将要运行的浏览器默认动作。
return false 之后的全部触发事件和动作都不会被运行。
參考资料
DOM事件模型:http://wenku.baidu.com/view/feafe986b9d528ea81c779e3.html
SD9011: 事件模型在各浏览器中存在差异:http://w3help.org/zh-cn/causes/SD9011
W3C DOM及其事件模型之初见:http://blog.csdn.net/yczxwestwood/article/details/6412997
stopPropagation, preventDefault 和 return false 的差别:http://www.neoease.com/stoppropagation-and-preventdefault-and-return-false/
W3C DOM 事件模型(简述)的更多相关文章
- javascript中0级DOM和2级DOM事件模型浅析
		Javascript程序使用的是事件驱动的设计模式,为一个元素添加事件监听函数,当这个元素的相应事件被触发那么其添加的事件监听函数就被调用: <input type="button&q ... 
- javascript中0级DOM和2级DOM事件模型浅析                                                    分类:            C1_HTML/JS/JQUERY             2014-08-06 15:22    253人阅读    评论(0)    收藏
		Javascript程序使用的是事件驱动的设计模式,为一个元素添加事件监听函数,当这个元素的相应事件被触发那么其添加的事件监听函数就被调用: <input type="button&q ... 
- JavaScript DOM 事件模型
		JavaScript DOM 事件模型 JavaScript 是基于面向对象和事件驱动的一门语言,事件模型是 DOM 中至关重要的内容,理解事件驱动机制.事件反馈.事件冒泡.事件捕获以及事件委托能帮助 ... 
- JavaScript DOM事件模型
		早期由于浏览器厂商对于浏览器市场的争夺,各家浏览器厂商对同一功能的JavaScript的实现都不进相同,本节内容介绍JavaScript的DOM事件模型及事件处理程序的分类. 1.DOM事件模型.DO ... 
- DOM事件模型浅析
		1.何为DOM DOM是"Document Object Model"的缩写,中文译为"文档对象模型".它是一种跨平台.跨语言的编程接口,将HTML,XHTML ... 
- DOM事件: DOM事件级别、DOM事件流、DOM事件模型、DOM事件捕获过程、自定义事件
		前端面试中只要问到事件,就肯定会有DOM事件:如果回答出来了,就会一直向下延申,其实这些东西都很简单,但我第一次被问到的时候,也是懵的: DOM事件级别: DOM0 element.onclick = ... 
- javascript 事件传播与事件冒泡,W3C事件模型
		说实话笔者在才工作的时候就听说了什么"事件冒泡",弄了很久才弄个大概,当时理解意思是子级dom元素和父级dom元素都绑定了相同类型的事件,这时如果子级事件触发了父级也会触发,然后这 ... 
- 前端基本知识(一):W3C标准&&冒泡事件,捕获事件,W3C DOM对象模型,对比分析
		W3C标准是万维网联盟, 其他的可以参考万维网版本的更新内容 一.W3C标准 二.W3C DOM事件 三.冒泡事件 四.捕获事件 一.W3C标准 其实网页是由三分部组成:1.结构(structure) ... 
- 【repost】JavaScript 事件模型 事件处理机制
		什么是事件? 事件(Event)是JavaScript应用跳动的心脏 ,也是把所有东西粘在一起的胶水.当我们与浏览器中 Web 页面进行某些类型的交互时,事件就发生了.事件可能是用户在某些内容上的点击 ... 
随机推荐
- codeforces 112APetya and Strings(字符串水题)
			A. Petya and Strings 点击打开题目 time limit per test 2 seconds memory limit per test 256 megabytes input ... 
- 流动python - 一个极简主义event制
			event至少该系统的核心,以满足: 1.存储容器事件,可以被添加到事件来删除 2.触发事件fire 守则. class Event(list): def __call__(self, *args, ... 
- codechef Little Elephant and Permutations题解
			The Little Elephant likes permutations. This time he has a permutation A[1], A[2], ..., A[N] of numb ... 
- 在Eclipse在使用JUnit4单元测试(0基础知识)
			自这篇文章: http://www.devx.com/Java/Article/31983/0/page/1 我们在编写大型程序的时候,须要写成千上万个方法或函数.这些函数的功能可能非常强大,但我们在 ... 
- SQL:多表关联采取这一纪录迄今为止最大
			笔者:iamlasong 1.需求 两个表,投递记录表和封发开拆记录表,如今想知道投递日期距最后一次封发日期天数分布情况. 对这个需求,须要先查询出投递明细,同一时候要知道相应的邮件最后一次封发情况. ... 
- contextmenu
			void Loaded(object sender, RoutedEventArgs e) { ContextMenu contextMenu = new ContextMenu(); context ... 
- 採用Android中的httpclient框架发送post请求
			/** * 採用httpclientPost请求的方式 * * @param username * @param password * @return null表示求得的路径有问题,text返回请求得 ... 
- C++习题 复数类--重载运算符+
			Description 定义一个复数类Complex,重载运算符"+",使之能用于复数的加法运算.将运算符函数重载为非成员.非友元的普通函数.编写程序,求两个复数之和. Input ... 
- Eclipse+Maven命令创建webapp项目<三>
			1.使用maven命令:mvn archetype:create -DgroupId=xxxxx -DartifactId=web-sample -DarchetypeArtifactId=maven ... 
- svn加入新的文件夹
			方法一: 1.在远程server上生成新的文件夹 svn mkdir http://svn.xxx.com/svn/mobile/strategy/assistant/branches/talk -m ... 
