js怎么绑定php中事件,详解js中的绑定事件和解绑事件

本篇文章主要介绍了js绑定事件和解绑事件的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧

在js中绑定多个事件用到的是两个方法:attachEvent和addEventListener,但是这两个方法又存在差异性

attachEvent方法 只支持IE678,不兼容其他浏览器

addEventListener方法 兼容火狐谷歌,不兼容IE8及以下

addEventListener方法p.addEventListener('click',fn);

p.addEventListener('click',fn2);

function fn(){ console.log("春雨绵绵"); }

function fn2(){

console.log("到处潮湿");

}

attachEvent方法p.attachEvent('onclick',fn);

p.attachEvent('onclick',fn2);

function fn(){ console.log("春雨绵绵"); }

function fn2(){

console.log("到处潮湿");

}

注意点:attachEvent方法绑定的事件是带on的,addEventListener绑定的事件是不带on的

下面我写了一个兼容了IE和火狐谷歌的方法var p=document.getElementsByTagName("p")[0];

addEvent('click',p,fn)

function addEvent(str,ele,fn){

ele.attachEvent?ele.attachEvent('on'+str,fn):ele.addEventListener(str,fn);

}

function fn(){

console.log("春雨绵绵");

}

这样就完美的解决了兼容性的问题

有绑定事件的话,那就肯定有解绑事件,但是解绑事件和绑定事件一样,万恶的IE还是会搞特殊化

detachEvent方法 只支持IE678,不兼容其他浏览器

removeEventListener方法 兼容火狐谷歌,不兼容IE8及以下

detachEvent方法写法:

ele.detachEvent("onclick",fn);

removeEventListener的写法:

ele.removeEventListener("click",fn);

下面我写了一个兼容性的方法给大家参考,实现也是很简单function remove(str,ele,fn){

ele.detachEvent?ele.detachEvent("on"+str,fn):ele.removeEventListener(str,fn);

}

注意点:不管是绑定事件attachEvent还是删除事件detachEvent都是要加on的,removeEventListenser和addEventListenser则不需要加on

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值