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);
小渣云 做那个你想都不敢想的套餐 你现在也许不知道小渣云 不过未来你将被小渣云的产品所吸引小渣云 专注于一个套餐的商家 把性价比 稳定性 以及价格做到极致的商家,也许你不相信36元在别人家1核1G都买不到的价格在小渣云却可以买到 8核8G 高配云服务器,并且在安全性 稳定性 都是极高的标准。小渣云 目前使用的是美国超级稳定的ceranetworks机房 数据安全上 每5天备份一次数据倒异地 支持一...
易探云怎么样?易探云是国内一家云计算服务商家,致力香港服务器、国内外服务器租用及托管等互联网业务,目前主要地区为运作香港BGP、香港CN2、广东、北京、深圳等地区。易探云服务器均选择当下热门线路,比如CN2 GIA、BGP线路、CN2线路等,所有云主机支持月付,并且首月优惠,年付优惠,优惠后香港沙田云服务器/独立ip/香港CN2线路,每月仅18元,188元/年。点击进入:易探云官方网站地址1、香港...
HostHatch在当地时间7月30日发布了一系列的促销套餐,涉及亚洲和欧美的多个地区机房,最低年付15美元起,一次买2年还能免费升级双倍资源。商家成立于2011年,提供基于KVM架构的VPS主机,数据中心包括中国香港、美国、英国、荷兰、印度、挪威、澳大利亚等国家的十几个地区机房。官方网站:https://hosthatch.com/NVMe VPS(香港/悉尼)1 CPU core (12.5%...
addeventlistener为你推荐
prisma安卓版prisma 安卓版本为什么不能使用一起作业网站一起作业官网是什么?listviewitemListView具有多种item布局pat是什么格式pat是什么格式的文件啊java程序员招聘★JAVA软件工程师工资待遇怎样云办公平台云办公平台对企业办公有什么好处呢?防火墙技术应用防火墙的应用与研究论文怎样删除聊天记录怎么批量清除微信聊天记录泛微协同办公系统泛微oa怎么样?我想了解一下,有用过的同仁帮忙!发表下自己的观点(天津)flushes翻譯下面的日記
华众虚拟主机管理系统 怎样注册域名 VPS之家 主机评测 42u标准机柜尺寸 名片模板psd 免费博客空间 嘟牛 台湾谷歌网址 193邮箱 七夕促销 腾讯实名认证中心 空间技术网 论坛主机 百度云空间 免费网络空间 江苏徐州移动 godaddy空间 1美元 双十二促销 更多