美文网首页
DOM事件流

DOM事件流

作者: 该昵称注册中 | 来源:发表于2017-12-27 22:21 被阅读0次

事件

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事件捕获冒泡与捕获

    事件流 JavaScript中,事件流指的是DOM事件流。 概念 事件的传播过程即DOM事件流。 事件对象在 DO...

  • DOM事件类

    基本概念:DOM事件的级别 DOM事件模型 DOM事件流 描述DOM事件捕获的具体流 Event对象的常见应用 自...

  • DOM事件面试题

    基本概念: DOM事件的级别 DOM事件模型image.png DOM事件流image.png什么是事件流:(分三...

  • 前端面试题(3)——DOM事件类

    基本概念:DOM事件的级别 DOM事件模型:事件冒泡事件捕获 DOM事件流 描述DOM事件捕获的具体流程 Even...

  • 复习笔记之API(6) DOM事件流

    DOM事件流 事件流描述的是从页面中接收事件的顺序(DOM事件流就是事件的传播过程)事件发生时会在元素节点之间按照...

  • 事件冒泡、事件捕获、事件委托

    一、DOM事件流 DOM事件流(event flow)存在三个阶段:事件捕获阶段、处于目标阶段、事件冒泡阶段,事件...

  • Dom事件

    Dom事件的级别Dom事件模型(冒泡+捕获)Dom事件流 http://www.cnblogs.com/staro...

  • Dom事件

    基本概念 Dom事件级别 Dom事件模型 Dom事件流 描述Dom事件捕获的具体流程 Event对象的常见应用 自...

  • 3-6 DOM事件

    问题 DOM 事件的级别 DOM 事件模型(就是捕获和冒泡儿) DOM 事件流 描述DOM事件捕获的具体流程 Ev...

  • 网易微专业-DOM编程艺术 05 事件

    1、DOM事件⑴主要内容▪事件流▪事件注册▪事件对象▪事件分类▪事件代理 ⑵什么是DOM事件▪点击一个DOM元素▪...

网友评论

      本文标题:DOM事件流

      本文链接:https://www.haomeiwen.com/subject/wfvpgxtx.html