zoukankan      html  css  js  c++  java
  • Js 事件侦听和删除

    事件侦听

    • addEventListener : 非 IE 7 8 下使用
    • 语法: 元素.addEventListener('事件类型', 事件处理函数, 冒泡还是捕获)

    要点:

    1. 侦听事件函数不能带入参数;
    2. 侦听事件函数有且仅有一个参数e,就是事件接收到事件对象,其他函数没有;
    3. 事件函数不能写return 返回值,但是可以用return跳出,不再执行下去;
       <button id="bn0">按钮</button>
       <script>
            var bn=document.querySelector("button");
            bn.addEventListener("click",clickHandler1);
            bn.addEventListener("click",clickHandler2);
                
            function clickHandler1(e){
                num++;
                console.log("aaa");
                if(num>1){
                    // this是事件侦听的对象
                    // e.currentTarget.removeEventListener("click",clickHandler1);
                    //将clickHandler1事件移除
                    this.removeEventListener("click",clickHandler1);
                }
            }
    
            function clickHandler2(e){
                // console.log("bbb");
                console.log(e.type)
            }
            
       </script>
    

    注意:

    - 当你点击 bn 的时候,两个函数都会执行,并且会按照你注册的顺序执行
    - 当元素的事件不再使用时,必须删除,否则会造成内存堆积,侦听事件都会被存储在堆中
    - 当元素被删除了,也必须删除该元素的所有事件
    
    • attachEvent :IE 7 8 下使用
    • 语法: 元素.attachEvent('事件类型', 事件处理函数)
    bn.attachEvent('onclick', function () {
     console.log('我是第一个事件')
    })
    ​
    bn.attachEvent('onclick', function () {
     console.log('我是第二个事件')
    })
    

    当你点击 bn 的时候,两个函数都会执行,并且会按照你注册的顺序倒叙执行
    先打印 我是第二个事件 再打印 我是第一个事件
    注意: 事件类型的时候要写 on,点击事件就行 onclick

    两个方式的区别

    • 注册事件的时候事件类型参数的书写

    addEventListener : 不用写 on
    attachEvent : 要写 on
    -参数个数
    addEventListener : 一般是三个常用参数
    attachEvent : 两个参数
    -执行顺序
    addEventListener : 顺序注册,顺序执行
    attachEvent : 顺序注册,倒叙执行
    -适用浏览器
    addEventListener : 非 IE 7 8 的浏览器
    attachEvent : IE 7 8 浏览器

    addEventListener() 和 onclick的区别:

    • onclick不能同时执行两个函数,addEventListener()可以执行两个不同的函数;
    • 移除事件侦听的方式不同
    document.onclick=function(){
    	document.onclick=null;//移除事件侦听
            console.log("a")
    }
    //事件会覆盖上面的事件
    document.onclick=function(){
        console.log("b");
    }
    
    document.addEventListener("click",clickHandler1);
    document.addEventListener("click",clickHandler2);
    function clickHandler1(e){
    	//移除事件侦听
    	document.removeEventListener("click",clickHandler1);
            console.log("a");
    }
    function clickHandler2(e){
               //不会覆盖上面的事件
              console.log("b");
    }
    
    
    • 事件匿名函数的不断迭代就会造成回调地狱,而使用事件注册时用的是命名函数就会减少造成回调地狱
    // 事件匿名函数的不断迭代就会造成回调地狱
    document.onclick=function(){
        var bn=document.querySelector("button");
        bn.onclick=function(){
            console.log("aaa");
        }
    }
    
    

    注意:以后写函数就不使用匿名函数

    • addEventListener可以在捕获阶段和冒泡阶段触发,而onclick只能冒泡阶段触发
     document.body.addEventListener("click", clickHandler);//冒泡阶段执行
     document.body.addEventListener("click", clickHandler,true);//捕获阶段执行
    
    
    • onclick支持IE低版本,addEventListener不支持IE8一下,低版本的IE使用 attachEvent 进行事件侦听;使用 detachEvent 移除事件侦听。
    document.attachEvent("onclick",clickHandler);//IE8及以下使用,其他版本和其他浏览器不支持
    function clickHandler(e){
        console.log("aaa");
        document.detachEvent("onclick",clickHandler);//移除事件侦听
    }
    
    

    事件侦听和移除的兼容写法:

    function addEvent(elem,type,eventHandler){
        try{
            elem.addEventListener(type,eventHandler);
        }catch(e){
            elem.attachEvent("on"+type,eventHandler);
        }
    }
    
    function removeEvent(elem,type,eventHandler){
        try{
            elem.removeEventListener(type,eventHandler);
        }catch(e){
            elem.detachEvent("on"+type,eventHandler);
        }
    }
    
    addEvent(document,"click",clickHandler);
    function clickHandler(){
    
    }
    
    

    高级版:事件侦听

    js部分

            //获取元素
            var bn0=document.getElementById("bn0");
             //绑定事件
            on(bn0,"click",clickHandler);
    
            function clickHandler(e){
                console.log(e);
            }
            
             //侦听事件
            function on(target,type,handler){
                var b=judgeBrowser("IE");
                if(b && Number(b)<9){
                    target.attachEvent("on"+type,handler);
                }else{
                    target.addEventListener(type,handler);
                }
           }
             /* 
            
                获取浏览器和版本
    
                通过浏览器打开,会返回当前浏览器名和版本号
                return 
                    数组   [浏览器:String,浏览器版本号:String]
            
             */
            function getBrowserRV(){
                var str=navigator.userAgent;
                // 判断是否是Chrome
                if(str.indexOf("Chrome")>-1){
                    var index=str.indexOf("Chrome");
                    return str.slice(index,str.indexOf(" ",index+1)).split("/");
                }
                 // 判断是否是Firefox
                if(str.indexOf("Firefox")>-1){
                    var index=str.indexOf("Firefox");
                    return str.slice(index).split("/");
                }
                // 判断是否是IE11
                if(str.indexOf("rv:")>-1 && str.indexOf("Trident")>-1){
                    return ["IE","11"];
                }
                // 判断是否是IE10及以下
                if(str.indexOf("Trident")>-1){
                    var index=str.indexOf("MSIE");
                    return ["IE",str.slice(index,str.indexOf(";",index)).split(" ")[1]];
                }
            }  
    
            
            //判断浏览器版本
             function judgeBrowser(browser){
                var arr=getBrowserRV();
                if(browser.toLowerCase()===arr[0].toLowerCase()){
                    return arr[1];
                }else{
                    return false;
                }
            }
    
           
       
    
  • 相关阅读:
    Android 显示或隐藏标题栏进度条TitleProgressBar
    Android 利用Sharp样式设置文本框EditText圆角形状
    Android 中带有进度条效果的按钮(Button)
    Android 手势滑动,多点触摸放大缩小图片
    Android (Notification)消息推送机制
    Android AutoCompleteTextView控件实现类似百度搜索提示,限制输入数字长度
    Android 横向列表GridView 实现横向滚动
    Android 利用 AsyncTask 异步读取网络图片
    Android 各种功能代码收集
    Android 之 AlarmManager(定时器) 的介绍和使用
  • 原文地址:https://www.cnblogs.com/my12-28/p/12726628.html
Copyright © 2011-2022 走看看