DOM事件流

事件

1:事件流

事件流描述的是从页面中接收事件的顺序。IE是事件冒泡( 从下往上一层一层的往上传),其他的为事件捕获(从docunment 一层一层的往下捕获).

事件处理程序,onclick,onload,onmouseover,每个都会创建一个封装元素属性值的函数,函数中有一个局部变量event ,为事件对象.

DOM0级对事件的处理

一:简单 二:具有跨浏览器的优势。 btn.onclick = function(){}; 被认为是该元素的方法,可以用方法中用this操作元素, 取消 btn.onclick=null

缺点,后面定义的onclick() 会把前面的覆盖

DOM2级事件处理程序

addEventListener(),removeEventListener() ,接收三个参数,1:要处理的事件名,2:作为事件处理程序的函数3: 布尔值.(true 为表示事件在捕获阶段调用事件处理程序,false 为在事件冒泡阶段调用事件处理程序)

好处:可以添加多个事件处理程序,触发顺序按照添加的顺序触发.

通过addEventListen()添加的事件处理程序只能用removeEventListener() 移除,移除时传入的参数必须和处理传入的参数必须一致.这就意味着通过addEventListener() 添加的匿名函数将无法移除.必须要

var btn = document.getElementById("myBtn");
var handle = function(){alert(this.id)};
btn.addEventListener("click",handle,false);
//移除  和添加方法的参数一样
btn.removeEventListener("click",handle,false)
IE事件处理程序

IE实现了和DOM 类似的两个方法,attachEvent()detachEvent() ,这两个方法只接受两个相同的参数,事件处理程序名称和事件处理函数.由于IE8只支持事件冒泡,通过attachEvent 添加的事件只会添加到冒泡阶段。注意添加的是onclick 不是上面的click.当调用detachEvent() 时,必须像removeEventListener() 一样传入的参数一样,意味着匿名函数不能被移除。添加多个方法的时候,执行顺序按添加相反的顺序触发

var btn =document.getElementById("myBtn");
btn.attachEvent("onclick",function(){
 alert(this === window); //true
})
事件对象

在触发DOM 事件时,都会产生一个event

阻止特定事件的默认行为.用preventDefault(). 例如阻止<a></a> 的跳转。

var link=document.getElemetById("myLink");

link.onclick=function(event){event.preventDefault()} //只有cancelable属性为true的才能用preventDefault 也可以 return false; 来阻止

event.stopPropagation() 用于立即停止事件在DOM 层次中的传播,取消进一步的事件捕获或捕获.从而避免触发不相干的的事件绑定.注意cancelBubble 属性 也可以阻止事件捕获.IE为事件冒泡.event.stopPropagation() 都可以阻止。

总的来说event.preventDefault();event.stopPropagation() 来阻止。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • JavaScript 程序采用了异步事件驱动编程模型。在这种程序设计风格下,当文档、浏览器、元素或与之相关的对象发...
    劼哥stone阅读 1,299评论 3 11
  • 事件流: 事件流:页面接收事件的顺序。 IE定义的:事件冒泡流(由最具体的元素依次传播到DOM树的最上层的Docu...
    xiaoguo16阅读 620评论 0 0
  • 声明:本文来源于http://www.webzsky.com/?p=731我只是在这里作为自己的学习笔记整理一下(...
    angryyan阅读 7,162评论 1 6
  • 一、问答 1. dom对象的innerText和innerHTML有什么区别? innerHTML: 也就是从对象...
    饥人谷_罗伟恩阅读 653评论 0 2
  • 刚爬床在想是不是应该跟你说些什么…我在想为什么你会这么容易放弃呢还有如果那天我不开口问那个问题是不是你就永远搁着呢...
    flowdiers阅读 189评论 0 1