zoukankan      html  css  js  c++  java
  • (转)addEventListener()与removeEventListener()详解

    转自:http://www.111cn.net/wy/js-ajax/48004.htm

    addEventListener()与removeEventListener()用于处理指定和删除事件处理程序操作。
    所有的DOM节点中都包含这两种方法,并且它们都接受3个参数:要处理的事件名、作为事件处理程序的函数和一个布尔值。
    最后这个布尔值参数是true,表示在捕获阶段调用事件处理程序;
    如果是false(false- 默认),表示在冒泡阶段调用事件处理程序。

    addEventListener的参数一共有三个,语法为:
    element.addEventListener(type,listener,useCapture)
    下面是详解:
    1、其中element是要绑定函数的对象。
    2、type是事件名称,要注意的是"onclick"要改为"click","onblur"要改为"blur",也就是说事件名不要带"on"。
    3、listener当然就是绑定的函数了,记住不要跟括号
    4、最后一个参数是个布尔值,表示该事件的响应顺序,下面重点介绍一下addEventListener的第3个参数(useCapture)。

    要在按钮上为click事件添加事件处理程序,可以使用下列代码:

    var btn = document.getElementById("myBtn");
    btn.addEventListener("click", function () {
        alert(this.id);
    }, false);        

    使用DOM2级方法添加事件处理程序的主要好处是可以添加多个事件处理程序。来看下面的例子:

    var btn = document.getElementById("myBtn");
    
    btn.addEventListener("click", function () {
        alert(this.id);
    }, false);    
    btn.addEventListener("click", function () {
        alert("Hello World");
    }, false);

    通过addEventListener()添加的事件处理程序只能使用removeEventListener()来移除;

    移除时传入的参数与添加处理程序时使用的参数相同。
    这也意味着通过addEventListener()添加的匿名函数无法移除,如下面的例子所示:

    var btn = document.getElementById("myBtn");
    
    btn.addEventListener("click", function () {
          alert(this.id);
    }, false);
    btn.removeEventListener("click", function () { //无效!
         alert(this.id);
    }, false);

    在这个例子中,我使用addEventListener()添加一个事件处理程序。
    虽然调用removeEventListener看似使用了相同的参数
    但实际上,第二个参数与传入addEventListener()中的是完全不同的函数。
    而传入removeEventListener()中的事件处理程序函数必须与传入addEventListener()中的相同,
    下面的例子所示:

    var btn = document.getElementById("myBtn");
    var handler = function () {
          alert(this.id);
    };
    btn.addEventListener("click", handler, false);
    btn.removeEventListener("click", handler, false); //有效! 

    重写后的这个例子没有问题,是因为在addEventListener()和removeEventListener()中用来相同的函数。
    实验结果是,用户点击button时,每次都会输出"I have been clicked!",说明removeEventListener()函数没有起到作用。

    通过查找资料,得出结论。在使用removeEventListener()函数时,handler函数,必须和使用addEventListener()里面的handler函数必须相同。
    所以上面写的代码是错误的。修正之后的代码应该如下:

    //addEventListener()和removeEventListener()中handler函数必须相同,移除事件函数才有效。
    function myhandler(){
        console.log("I have been clicked!");
        document.getElementById('info').removeEventListener('click',myhandler,false);
    }
    var target=document.getElementById('info');
    target.addEventListener("click", myhandler, false);
    target.removeEventListener("click", myhandler, false); //有效! 
  • 相关阅读:
    Java DVD管理项目
    Java 幸运抽奖项目
    VS中C#读取app.config数据库配置字符串的三种方法(转)
    IE浏览器让人呕吐的事情!
    你不知道的Javascript小结
    sdfdfd
    mvc中viewData和TempData的区别
    ajax最头疼的问题浏览器兼容
    javascript事件冒泡和捕获
    C# 模拟自动登录的一种简单方式
  • 原文地址:https://www.cnblogs.com/JsonShare/p/6737499.html
Copyright © 2011-2022 走看看