在慕课网上学习了DOM事件探秘课程,特此整理了一下笔记。

  慕课网DOM事件探秘课程地址:http://www.imooc.com/learn/138

事件

  是文档或浏览器窗口中发生的特定的交互瞬间。【JavaScript <------>HTML】

事件流

  描述的是从页面中接受事件的顺序 (IE:事件冒泡流 / Netscape事件捕获流)

事件的三个阶段

  事件的三个阶段分别是:捕获阶段、目标阶段、冒泡阶段

  事件冒泡流:即事件最开始由最具体的无素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到最不具体的那个节点(文档) input----->document

  事件捕获:不太具体的节点应该更早接收到事件,而最具体的节点最后接收到事件。跟事件冒泡截然相反

  事件冒泡:从最内层至最外层(最常用)

  事件捕获:从最外层至最内层

事件处理程序

1.HTML事件处理程序(现在不建议使用了):事件直接加在HTML代码中

<input type="button" value="按钮" id="btn" onclick="alert('hellow')">

  <input type="button" value="按钮" id="btn" onclick="show()">

缺点:①HTML和js代码高耦合,如果修改,就要修改两个地方--HTML元素内和script函数。

     ②可能存在时差问题。考虑这样一种情形。show函数定义在按钮的后面,当DOM还没有加载到script标签的时候将会发生错误,此种情形可以通过内部添加try-catch来解决;或者将script标签放到页面顶部,但会延迟页面的加载速度。

2.DOM0级事件处理程序 (用得比较多)浏览器4代出现

  较传统的方式:把一个函数赋值给一个事件处理程序的属性。  

  优点:简单,跨浏览器  

  var btn=document.getElementById("btn2");---先获取出元素,定义对象 //取得btn按钮对象  

  btn.onclick=function(){alert('这是通过DOM0级添加的事件!')}----让 事件以对象的属性 的形式出现。 //给btn添加onclick属性 

  btn.onclick=null;-----删除onclick属性。

3.DOM2级事件处理程序

  定义了两个方法--用于处理指定和删除事件处理程序的操作:

  addEventListener()添加事件监听程序

  removeEventListener()移除事件监听程序

  三个参数设置;事件名称,处理方法(函数),布尔值--false:表示在冒泡阶段调用事件处理程序(可以最大限度的兼容浏览器),一般设为false;true表示在捕获阶段调用事件处理程序

  btn.addEventListener('click',showMes,false);  //showMes为方法名

  注意:

  ①、若事件名称有on,则需去掉on。onclick --> click,onmouseover --> mouseover等等;

  ②、false 最大限度兼容所有浏览器--事件冒泡流。

  ③、通过addEventListener添加的事件只能通过removeEventListener来删除。--参数要与添加事件时相同

  btn.removeEventListener(参数); //参数必须和btn.addEventListener的参数一致,删除事件监听

  DOM0级和DOM2级事件处理程序可以给一个事件绑定多个函数,事件触发的时候会按照绑定顺序执行各个函数。如下所示:

  btn.addEventListener('click',showMes,false);

  btn.addEventListener('click',showMes,function(){alert(this.value);},false);

  缺点:IE不支持该事件

  DOM2级删除事件不能直接使用匿名函数。

  btn3.addEventListener('click',function(){alert("this.value");},false); //添加事件有效

  btn3.removeEventListener('click',function(){alert("this.value");},false); //删除事件无效

  因为匿名函数看起来是一样的,其实是两个不同的对象。

  btn3.addEventListener('click',function(){alert("this.value");},false);

  btn3.removeEventListener('click',function(){alert("this.value");},false);

  这两行代码中的function(){alert(alert("this.value"));}看上去是同一个东西,实际上是不同的对象,而removeEventListener要求函数必须一样。

  所以addEventListener最好还是用将匿名函数赋值给某个变量

  addEventListener('click',showValue,false);

  removeEventListener('click',showValue,false);

  这样就不会出bug了。

  加括号——调用函数

  只要是要调用函数执行的,都必须加括号。此时,function()实际上等于函数的返回值。(没有返回值也已经执行了函数体内的行为)。就是说,只要加括号的,就代表将会执行函数体代码。  

  不加括号——指定函数引用  

  把函数名作为函数指针,用于传参,此时不是得到函数结果,因为不会运行函数体代码。它只是传递了函数体所在地址,在需要时找到函数体去执行。

4.IE事件处理程序

  attachEvent()添加事件和detachEvennt()删除事件

  接收相同的两个参数:事件处理程序的名称和事件处理程序的函数,加on,没有布尔值;

  不加第三个参数的原因:IE8及更早的浏览器版本只支持事件冒泡

  btn.attachEvent('onclick',showMes);

  支持IE事件处理程序的浏览器:IE和OPERA

  btn.detachEvent('onclick',showMes);

事件对象event

  在触发DOM上的事件时都会产生一个对象。

  1、DOM中的事件对象

    ①、type属性,用于获取事件类型  event.type

    ②、target属性,用于获取事件目标  event.target

    ③、stopPropagation()方法,用于阻止事件冒泡

    ④、preventDefault()方法,阻止事件的默认行为,比如a标签的跳转

    如果一个div里面有一个button,button和div都绑定了click事件,如果是事件冒泡,那么点击button的时候,首先触发button的处理函数,然后触发div的处理函数。(由内而外)

    如果有时候不想冒泡,也就是不希望div的事件被触发,那么需要阻止事件冒泡。stopPropagation()方法

    如果需要阻止a标签的默认属性跳转,可以使用阻止事件的默认行为preventDefault()方法

  2、IE事件对象(window.event)

    ①、事件类型:event.type  type属性,用于获取事件类型

    ②、事件目标:event.srcElement  srcElement属性,用于获取事件的目标

    ③、阻止事件冒泡:event.cancelBubble = true  cancelBubble属性,用于阻止事件冒泡  设置为true表示阻止冒泡,设置为false表示不阻止冒泡

    ④、阻止默认事件:event.returnValue = false  returnValue属性,用于阻止事件的默认行为  设置为false表示阻止事件的默认行为

  事件处理程序执行完后,event对象将被销毁;在事件处理程序内部this === currentTarget,而target则表示的是事件的实际目标,

  事件委托就是事件目标自身不处理事件,而是把处理任务委托给其父元素或者祖先元素,甚至根元素(document)。因为子节点触发事件的时候,会冒泡到父节点,触发该事件,这样就可以避免新加节点就绑定事件

跨浏览器处理程序封装

/*
* [eventUtil 事件处理程序]
*/
var eventUtil={
//添加事件
addEvent:function(element,type,handler){
if(element.addEventListener){
element.addEventListener(type,handler,false); //DOM2级
}else if(element.attachEvent){
element.attachEvent('on'+type,handler); //IE处理程序
}else{
element['on'+type]=handler; //DOM0级 element.onclick === element['onclick']
}
},
//删除事件
removeEvent:function(element,type,handler){
if(element.removeEventListener){
element.removeEventListener(type,handler,false);
}else if(element.detachEvent){
element.detachEvent('on'+type,handler);
}else{
element['on'+type]=null;
}
},
//获取事件
getEvent:function(event){
return event?event:window.event;
},
//获取事件类型
getEventType:function(event){
return event.type;
},
//获取事件对象
getEventTarget:function(event){
return event.target || event.srcElement;
},
//阻止事件的默认行为
preventDefault:function(event){
if(event.preventDefault){
event.preventDefault();
}else{
event.returnValue = false;
}
},
//阻止事件冒泡
stopPropagation:function(event){
if(event.stopPropagation){
event.stopPropagation();
}else{
event.cancelBubble = true;
}
},
}

 

 

DOM事件的更多相关文章

  1. DOM 事件深入浅出(二)

    在DOM事件深入浅出(一)中,我主要给大家讲解了不同DOM级别下的事件处理程序,同时介绍了事件冒泡和捕获的触发原理和方法.本文将继续介绍DOM事件中的知识点,主要侧重于DOM事件中Event对象的属性 ...

  2. DOM 事件深入浅出(一)

    在项目开发时,我们时常需要考虑用户在使用产品时产生的各种各样的交互事件,比如鼠标点击事件.敲击键盘事件等.这样的事件行为都是前端DOM事件的组成部分,不同的DOM事件会有不同的触发条件和触发效果.本文 ...

  3. 理解DOM事件流的三个阶段

    本文主要解决两个问题: 1.什么是事件流 2.DOM事件流的三个阶段 事件流之事件冒泡与事件捕获 在浏览器发展的过程中,开发团队遇到了一个问题.那就是页面中的哪一部分拥有特定的事件? 可以想象画在一张 ...

  4. 你真的了解DOM事件么?

    你真的了解DOM事件么? 我们大家都知道,人与人之间的交流可以通过语言,文字,肢体动作,面部微表情等,但是你知道Javascript和HTML之间是通过什么进行交互的么?你又知道Javascript和 ...

  5. [DOM Event Learning] Section 4 事件分发和DOM事件流

    [DOM Event Learning] Section 4 事件分发和DOM事件流 事件分发机制: event dispatch mechanism. 事件流(event flow)描述了事件对象在 ...

  6. dom事件与event对象总结

    1 事件:就是文档或浏览器窗口中发生的一些特定的交互瞬间.    tips:js和xhtml的交互是通过当用户或浏览器操作网页时发生的事件来处理的. 1.1 事件流:即事件的顺序.        事件 ...

  7. DOM事件简介--摘自admin10000

    Click.touch.load.drag.change.input.error.risize — 这些都是冗长的DOM(文档对象模型)事件列表的一部分.事件可以在文档(Document)结构的任何部 ...

  8. 从click事件理解DOM事件流

    事件流是用来解释页面上的不同元素接受一个事件的顺序,首先要明确两点: 1.一个事件的影响元素可能不止一个(同心圆理论),但目标元素只有一个. 2.如果这些元素都绑定了相同名称的事件函数,我们怎么知道这 ...

  9. DOM事件机制进一步理解

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...

随机推荐

  1. javascript 技巧总结积累(正在积累中)

    1.文本框焦点问题 onBlur:当失去输入焦点后产生该事件 onFocus:当输入获得焦点后,产生该文件 Onchange:当文字值改变时,产生该事件 Onselect:当文字加亮后,产生该文件 & ...

  2. Git on Windows 一些问题

    问题汇总 1. 卸载Git时,bin和usr目录删不掉 报错:bin, usr目前需要admin权限删除,或者这个目录被其他文件引用 打开taskmgr,找到所有引用 git/bin/ 下的文件的进程 ...

  3. Alpha版总结会议

    昨天上课的时候,我们学习了项目总结这一部分的内容,并根据老师提供的项目Postmortem模板对我们的项目进行了总结. 项目Postmortem模板主要分为设想和目标.计划.资源.变更管理.设计和实现 ...

  4. 在Node.js使用mysql模块时遇到的坑

    之前写了个小程序Node News,用到了MySQL数据库,在本地测试均没神马问题.放上服务器运行一段时间后,偶然发现打开页面的时候页面一直处于等待状态,直到Nginx返回超时错误.于是上服务器检查了 ...

  5. 提升PHP编程效率的20个要素

    用单引号代替双引号来包含字符串,这样做会更快一些.因为PHP会在双引号包围的字符串中搜寻变量,单引号则 不会,注意:只有echo能这么做,它是一种可以把多个字符串当作参数的“函数”(兄弟连PHP编程: ...

  6. Virus.Win32.Virlock.b分析

    0x00 样本说明 分析样本是被0b500d25f645c0b25532c1e3c9741667的样本感染得到.感染前的文件是Tcpview.exe,一款windows网络连接查看工具. 感染前后文件 ...

  7. ubuntu-docker-etcd-swarm-shipyard-portainer

    --- env --- root@node1:~# cat /etc/issueUbuntu 12.04.4 LTS \n \l root@node1:~# docker -vDocker versi ...

  8. win8 app GridView点击子项布局变更

    要触发点击必须设置IsItemClickEnabled="True" 要变更布局代码如下: private void gridView_ItemClick_1(object sen ...

  9. UIPickerView去掉背景上的黑线

    - (UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger) ...

  10. 【日记】thinkphp项目阿里云ECS服务器部署

    项目本地开发告一段落.准备上传到服务器上测试 技术组成 thinkphp+mysql+阿里ECS  代码管理方式git 一.阿里ECS服务器配置 1.因为线上已经有几个站点了.所以要配置ngnix多站 ...