addEventListener和on的区别
addEventListener和on的区别
为什么需要addEventListener?
先来看一个片段:
html代码
<div id="box">追梦子</div>
用on的代码
1 window.onload = function(){
2 var box = document.getElementById("box");
3 box.onclick = function(){
4 console.log("我是box1");
5 }
6 box.onclick = function(){
7 box.style.fontSize = "18px";
8 console.log("我是box2");
9 }
10 }
运行结果:“我是box2”
看到了吧,第二个onclick把第一个onclick给覆盖了,虽然大部分情况我们用on就可以完成我们想要的结果,但是有时我们又需要执行多个相同的事件,很明显如果用on完成不了我们想要的,那不用猜,你们肯定知道了,对!addEventListener可以多次绑定同一个事件并且不会覆盖上一个事件。
用addEventListener的代码
1 window.onload = function(){
2 var box = document.getElementById("box");
3 box.addEventListener("click",function(){
4 console.log("我是box1");
5 })
6 box.addEventListener("click",function(){
7 console.log("我是box2");
8 })
9 }
运行结果:我是box1
我是box2
addEventListenert方法第一个参数填写事件名,注意不需要写on,第二个参数可以是一个函数,第三个参数是指在冒泡阶段还是捕获阶段处理事件处理程序,如果为true代表捕获阶段处理,如果是false代表冒泡阶段处理,第三个参数可以省略,大多数情况也不需要用到第三个参数,不写第三个参数默认false
第三个参数的使用
有时候的情况是这样的
<body>
<div id="box">
<div id="child"></div>
</div>
</body>
如果我给box加click事件,如果我直接单击box没有什么问题,但是如果我单击的是child元素,那么它是怎么样执行的?(执行顺序)
1 box.addEventListener("click",function(){
2 console.log("box");
3 })
4
5 child.addEventListener("click",function(){
6 console.log("child");
7 })
执行的结果:
child
box
也就是说,默认情况事件是按照事件冒泡的执行顺序进行的。
如果第三个参数写的是true,则按照事件捕获的执行顺序进行的。
1 box.addEventListener("click",function(){
2 console.log("box");
3 },true)
4
5 child.addEventListener("click",function(){
6 console.log("child");
7 })
执行的结果:
box
child
事件冒泡执行过程:
从最具体的的元素(你单击的那个元素)开始向上开始冒泡,拿我们上面的案例讲它的顺序是:child->box
事件捕获执行过程:
从最不具体的元素(最外面的那个盒子)开始向里面冒泡,拿我们上面的案例讲它的顺序是:box->childaddEventListener和普通.onclick的区别
addEventListener是在 FireFox 上的用法。
?
addEventListener的参数一共有三个,语法为:?
element.addEventListener(type,listener,useCapture)?
详解?
其中element是要绑定函数的对象。
?
type是事件名称,要注意的是"onclick"要改为"click","onblur"要改为"blur",也就是说事件名不要带"on"。
?
listener当然就是绑定的函数了,记住不要跟括号?
最后一个参数是个布尔值,表示该事件的响应顺序,下面重点介绍一下addEventListener的第3个参数(useCapture)。
?
userCapture若为true,则浏览器采用Capture,若为false则采用bubbing方式。
建议用false?
区别:
1
2
3
4
5
var?btn1Obj?=?document.getElementById("btn1");??
//element.addEventListener(type,listener,useCapture);??
btn1Obj.addEventListener("click",method1,false);??
btn1Obj.addEventListener("click",method2,false);??
btn1Obj.addEventListener("click",method3,false);
执行顺序为method1->method2->method3?
1
2
3
document.getElementById("btn").onclick?=?method1;??
document.getElementById("btn").onclick?=?method2;??
document.getElementById("btn").onclick?=?method3;
如果这样写,那么将会只有medhot3被执行晕了addEventListener怎么往里面传参
//addEventListener的使用方式:<br><br>target.addEventListener(type,listener,useCapture);<br><br>//target:文档节点、document、window或XMLHttpRequest。
<br>//type:字符串,事件名称,不含“on”,比如“click”、“mouseover”、“keydown”等。
<br>//listener:实现了EventListener接口或者是JavaScript中的函数。
<br>//useCapture:是否使用捕捉,一般用false。
例如:document.getElementById("testText").addEventListener("keydown",function(event){alert(event.keyCode);},false);如何使用addEventListener添加事件
使用attchEvent和detachEvent添加、注销事件;
火狐和其他浏览器都不支持,幸运的是他们都支持W3C标准的:
addEventListener和removeEventListener方法
形如:element.addEventListener(type,listener,useCapture);//添加事件
element.removeEventListener(type,listener,useCapture);//注销事件
这里需要和attchEvent相区别,event直接写事件名即可,如click事件->object.addEventListener("click",listener,useCapture);
LOCVPS发来了针对XEN架构VPS的促销方案,其中美国洛杉矶机房7折,其余日本/新加坡/中国香港等机房全部8折,优惠后日本/新加坡机房XEN VPS月付仅29.6元起。这是成立较久的一家国人VPS服务商,目前提供美国洛杉矶(MC/C3)、和中国香港(邦联、沙田电信、大埔)、日本(东京、大阪)、新加坡、德国和荷兰等机房VPS主机,基于XEN或者KVM虚拟架构,均选择国内访问线路不错的机房,适合建...
HostKvm也发布了开年促销方案,针对香港国际和美国洛杉矶两个机房的VPS主机提供7折优惠码,其他机房业务提供8折优惠码。商家成立于2013年,提供基于KVM架构的VPS主机,可选数据中心包括日本、新加坡、韩国、美国、中国香港等多个地区机房,均为国内直连或优化线路,延迟较低,适合建站或者远程办公等。下面列出几款主机配置信息。美国洛杉矶套餐:美国 US-Plan1CPU:1core内存:2GB硬盘...
收到好多消息,让我聊一下阿里云国际版本,作为一个阿里云死忠粉,之前用的服务器都是阿里云国内版的VPS主机,对于现在火热的阿里云国际版,这段时间了解了下,觉得还是有很多部分可以聊的,毕竟,实名制的服务器规则导致国际版无需实名这一特点被无限放大。以前也写过几篇综合性的阿里云国际版vps的分析,其中有一点得到很多人的认同,那句是阿里云不管国内版还是国际版的IO读写速度实在不敢恭维,相对意义上的,如果在这...
addeventlistener为你推荐
scriptmanagerscriptmanager.registerstartupscript是.net3.5吗youtube创始人李开复的创新工场是做什么的啊???pat是什么格式pat 格式的文件用什么软件打开?sms是什么什么是SMS协议腾讯合作伙伴大会腾讯位置服务是什么?动画分镜头脚本请问什么是动画分镜头脚本,什么是电影分镜头脚本以及什么是广告分镜头脚本?防火墙技术应用常用防火墙技术有哪几种泛微协同办公系统泛微oa怎么样?我想了解一下,有用过的同仁帮忙!发表下自己的观点(天津)微盟价格虚拟币的价格由什么决定camel是什么意思“压垮骆驼的最后一根稻草”是什么意思?
什么是二级域名 mediafire下载工具 贵州电信宽带测速 创宇云 135邮箱 百度云1t 购买国外空间 常州联通宽带 申请免费空间和域名 无限流量 创建邮箱 google台湾 服务器是干什么用的 河南移动梦网 丽萨 主机管理系统 申请免费空间 重庆联通服务器托管 ncp是什么 美国代理服务器 更多