zoukankan      html  css  js  c++  java
  • js绑定事件和解绑事件

     

     

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

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

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

    addEventListener方法

    复制代码
    div.addEventListener('click',fn);
    div.addEventListener('click',fn2);
    function fn(){ console.log("春雨绵绵"); }
    function fn2(){
                    console.log("到处潮湿");
                }
     
    复制代码

    attachEvent方法

    复制代码
    div.attachEvent('onclick',fn);
    div.attachEvent('onclick',fn2);
    function fn(){ console.log("春雨绵绵"); }
    function fn2(){
                    console.log("到处潮湿");
                }
    复制代码

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

    下面我写了一个兼容了IE和火狐谷歌的方法

    复制代码
    var div=document.getElementsByTagName("div")[0];
                addEvent('click',div,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);

    下面我写了一个兼容性的方法给大家参考,实现也是很简单

    1
    2
    3
    function remove(str,ele,fn){
                    ele.detachEvent?ele.detachEvent("on"+str,fn):ele.removeEventListener(str,fn);
                }

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

  • 相关阅读:
    3d服务器配置
    Can't connect to postgres on centos with psycopg
    flask快速入门
    nohup: cannot run command “/bin/java”:
    linux 上redis的启动口令
    CentOS网络设置 couldn't resolve host 'mirrorlist.centos.org问题解决
    CentOS下使用Mysql
    解决nodejs跨域的一个中间件
    JS实现禁用滑动条但滑动条不消失的效果
    JQ实现下拉加载更多
  • 原文地址:https://www.cnblogs.com/xzzzys/p/7797807.html
Copyright © 2011-2022 走看看