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);
小白云是一家国人自营的企业IDC,主营国内外VPS,致力于让每一个用户都能轻松、快速、经济地享受高端的服务,成立于2019年,拥有国内大带宽高防御的特点,专注于DDoS/CC等攻击的防护;海外线路精选纯CN2线路,以确保用户体验的首选线路,商家线上多名客服一对一解决处理用户的问题,提供7*24无人全自动化服务。商家承诺绝不超开,以用户体验为中心为用提供服务,一直坚持主打以产品质量用户体验性以及高效...
国庆钜惠 最低5折起 限量促销CYUN专注海外精品服务器资源,主营香港CN2 GIA、美国CERA、美国高防服务器资源,实体公司,ISP/IDC资质齐全,客服配备齐全。本次针对国庆推出非常给力的促销活动,旗下所有平台同享,新老客户同享,限时限量,售完截止。活动截止时间:2021年10月9日官网地址:www.cyun.net参与机型:香港CN2 GIA云服务器、香港双程CN2云服...
virmach这是第二波出这种一次性周期的VPS了,只需要缴费1一次即可,用完即抛,也不允许你在后面续费。本次促销的是美国西海岸的圣何塞和美国东海岸的水牛城,周期为6个月,过后VPS会被自动且是强制性取消。需要临时玩玩的,又不想多花钱的用户,可以考虑下!官方网站:https://www.virmach.comTemporary Length Service Specials圣何塞VPS-一次性6个...
addeventlistener为你推荐
broadcast播播……拼音qq管家官网在qq电脑管家官网有个可以登录qq的。登录上了可以加速么?java程序员招聘Java程序员,一般招聘都要求些啥特斯拉model3降价特斯拉官网为何会被挤崩?怎样删除聊天记录如何删除和一个人的聊天记录?flash序列号求flash的序列号acceptchangesaltium designer 6.0如何给元件重新编号flex是什么Adobe是什么软件?网页背景音乐代码网页背景音乐代码,我要哪怕转换网页都不间断的那种ibooks支持什么格式ibooks支持什么格式的电子书
草根过期域名 x3220 联通c套餐 主机测评网 国外服务器 流媒体服务器 100x100头像 双拼域名 双线主机 hinet 新家坡 lol台服官网 免费活动 免费全能主机 上海电信测速 云服务器比较 免费个人主页 免费蓝钻 阿里云邮箱个人版 学生机 更多