向元素添加事件句柄的语法:element.addEventListener(event, function, useCapture);

第一个参数是事件的类型,如click或者mousedown,注意前面都没有on

第二个是事件触发后调用的函数

第三个参数为布尔值,可选,默认值为false,即冒泡传递

例如

<button id="myBtn">点我</button>
<script>
document.getElementById("myBtn").addEventListener("click", function(){alert("Hello World!");});
</script>
<button id="myBtn">点我</button>
<script>
document.getElementById("myBtn").addEventListener("click", myFunction);
function myFunction() {alert ("Hello World!");}
</script>

上述第一种情况时直接写明函数与内容,第二种情况是通过函数名调用函数,这两种情况是等价的,并且与直接给元素添加事件是等价的。

注意,直接给元素添加事件时,是通过'函数名()'指明事件的,函数名后面有括号,并且整体通过''引用,而添加事件句柄时,直接通过函数名引用,没有括号也没有引号。

<button id="myBtn" onclick='myFunction()'>点我</button>
<script>
function myFunction() {alert ("Hello World!");}
</script>

移除事件句柄:element.removeEventListener(event, function);

<p style='background:pink' id='p'>段落</p>
<button onclick='myClick()'>点我移除生成随机数的事件句柄</button>
<script>
document.getElementById("p").addEventListener('mousemove',myFunction)
function myFunction(){document.getElementById("p").innerHTML=Math.random();}
function myClick(){document.getElementById("p").removeEventListener('mousemove',myFunction);}
</script>

如下,当鼠标在粉色段落框内移动时,段落内容随着鼠标移动而变成随机数,点击按钮后再在段落内移动,段落内容保持最后的不变。

可以向一个元素添加多个不同的事件句柄,也可以是两个同类型的事件例如两个click事件,后添加的事件句柄不会覆盖之前的事件句柄。

事件传递有两种方式:冒泡与捕获。

事件传递定义了元素事件触发的顺序。 如果<p>元素包含在<div>元素中,并且这两个元素都有一个click事件句柄,当用户点击<p>元素时,哪个元素的 "click" 事件先被触发呢?

在冒泡中,内部元素的事件会先被触发,然后再触发外部元素,即<p>元素的点击事件先触发,然后再触发<div>元素的点击事件。

在捕获中,外部元素的事件会先被触发,然后再触发内部元素,即<div>元素的点击事件先触发 ,然后再触发<p>元素的点击事件。

addEventListener() 方法可以指定 "useCapture" 参数来设置传递类型,默认值为false即冒泡传递,当值为 true 时事件使用捕获传递。

例如,如下

<div class="outer">
I'm outer
<p class="inner">I'm inner</p>
</div>
<script>
var ele1=document.getElementsByClassName('outer')[0];
var ele2=document.getElementsByClassName('inner')[0];
ele1.onclick=function(){alert('I\'m outer')}
ele2.onclick=function(){alert('I\'m inner')}
</script>

在点击inner框时,会先弹出I'm inner再弹出I'm outer。如果想只执行本元素事件而不触发父元素事件,可向子元素的事件函数传递参数e,并通过e.stopPropagation()阻止事件传递。

ele2.onclick=function(e){
alert('I\'m inner');
e.stopPropagation()}

DOM EventListener的更多相关文章

  1. JavaScript HTML DOM EventListener

    JavaScript HTML DOM EventListener addEventListener() 方法 实例 点用户点击按钮时触发监听事件: document.getElementById(& ...

  2. JavaScript要点(十三) HTML DOM EventListener

    addEventListener() 方法 <body> <p>该实例使用 addEventListener() 方法在按钮中添加点击事件. </p> <bu ...

  3. DOM - EventListener 句柄操作

          <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" c ...

  4. 第三天:DOM EventListener 句柄的添加和移除

    1.事件句柄的包含如下两个方法: ps:使用句柄的好处是,修改方法的名称时,不需要改变多处 1.添加一个句柄, 2.添加多个句柄不会覆盖,运行结果:点击“按钮”,弹出框hello,确定后,自动弹出框w ...

  5. 吴裕雄--天生自然 JAVASCRIPT开发学习:DOM EventListener

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

  6. javascript DOM对象

    DOM简介 1.html DOM:当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model) 2.DOM操作html JS能改变页面中的所有html元素 JS能改变页 ...

  7. javascript 之DOM篇

    要怎么样的开场白才能使我有力气再更新学习进度呢?啊啊啊啊啊,表示好累啊~~~默念“棒棒棒,我最棒~”召唤精气神开总结敲字咯.哈哈哈. --------------------------------- ...

  8. js备战春招の四のDOM

    通过js查找html元素的三种方法: 1.通过id找到html元素. 2.通过标签名找到html元素. 3.通过类名找到html元素. DOM HTML document.write(); 直接写入h ...

  9. javascript HTML DOM 简单介绍

    JavaScript HTML DOM通过 HTML DOM,可访问 JavaScript HTML 文档的所有元素.HTML DOM (文档对象模型)当网页被加载时,浏览器会创建页面的文档对象模型( ...

随机推荐

  1. 采用Extjs MVVM + ThinkPHP 架构开发的思考

    前后台号称都是MVC模式, 后台ThinkPHP框架实际上只提供web操作接口,直接返回json数据,因此只能算有Model和Controller两层, 前台ExtjsMVVM模式实际上就是分模块后的 ...

  2. InstallShield12的安装破解方法

    InstallShield是一个非常专业的windows程序打包工具,利用它我们可以轻松方便地将我们开发的windows程序进行封装打包.下面呢我就以我自己的实际操作经历来给大家介绍一下如何安装和破解 ...

  3. MySQL--5子查询与连接小结

    子查询:出现在其他sql语句中的 SELECT,必须出现在小括号内,子查询外层可以是常见的SELECT语句,INSERT语句 UPDATE语句 DELETE语句,在子查询中可以包含多个关键字和条件 ( ...

  4. JS日期格式化扩展

    1.扩展 //扩展日期 Date.prototype.Format = function (fmt) { //author: meizz var o = { , //月份 "d+" ...

  5. selenium元素高亮显示

    selenium元素高亮显示: 采用js注入的方式,通过更改元素样式来实现. border:2px 边框  solid red 红色 def hightlight(self,element): &qu ...

  6. 12月centos单词

    ---恢复内容开始--- UNreachable:adj.(network server unreachable) 不能达到的; 及不到的; 取不到的; 不能得到的; rsync: rsync [re ...

  7. teragen/terasort_简化版

    1, 关闭Hadoop安全模式 进入hdfs用户 su – hdfs Cd /opt/cloudera/parcels/CDH-5.12.1-1.cdh5.12.1.p0.3/bin hdfs dfs ...

  8. java微信小程序调用支付接口

    简介:微信小程序支付这里的坑还是有的,所以提醒各位在编写的一定要注意!!! 1.首先呢,你需要准备openid,appid,还有申请微信支付后要设置一个32位的密钥,需要先生成一个sign,得到pre ...

  9. RSA加解密 私钥加密公钥解密 私加公解 && C++ 调用openssl库 的代码实例

    前提:秘钥长度=1024 ============================================== 对一片(117字节)明文加密  私加 ===================== ...

  10. LeetCode12.整数转罗马数字

    给定一个整数,将其转为罗马数字.输入确保在 1 到 3999 的范围内. 示例 1: 输入: 3 输出: "III" 示例 2: 输入: 4 输出: "IV" ...