zoukankan      html  css  js  c++  java
  • addEventListener调用带参数函数

    当传递参数值时,使用"匿名函数"调用带参数的函数:

    <body>
      <button id="btn">click me</button>
      <p id="show"></p>
      <script>
         var p1=5;
         var p2=7;         
    document.getElementById(
    "btn").addEventListener("click",
    function(){
    add(p1,p2);
    })
    function add(a,b){ var sum=a+b; document.getElementById("show").innerHTML=sum; } </script> </body>

    若直接传add(p1,p2),不需要点击,直接显示运算结果。

    原因:

    第二个参数是一个函数,传add(p1,p2)的话,相当于传的add(p1,p2)返回值。

    addEventListener补充:

    1. 可以在文档中添加许多事件,添加的事件不会覆盖已存在的事件。

    document.getElementById("myBtn").addEventListener("click", myFunction);
    document.getElementById("myBtn").addEventListener("click", someOtherFunction);

    2. 可以在同一个元素中添加不同类型的事件。

    document.getElementById("myBtn").addEventListener("mouseover", myFunction);
    document.getElementById("myBtn").addEventListener("click", someOtherFunction);
    document.getElementById("myBtn").addEventListener("mouseout", someOtherFunction);

    3. Internet Explorer 8 及更早IE版本不支持 addEventListener() 方法,,Opera 7.0 及 Opera 更早版本也不支持。 但是,对于这些不支持该函数的浏览器,你可以使用 attachEvent() 方法来添加事件句柄

    var x = document.getElementById("myBtn");
    if (x.addEventListener) {                    //所有主流浏览器,除了 IE 8 及更早 IE版本
        x.addEventListener("click", myFunction);
    } else if (x.attachEvent) {                  // IE 8 及更早 IE 版本
        x.attachEvent("onclick", myFunction);
    }
  • 相关阅读:
    typescript 深层次对象内层(N)转外层(N),支持多层级递归转换,多应用于多语言数据结构转换
    js 柯里化、深拷贝、浅拷贝
    js IntersectionObserver api
    javascript-state-machine
    NodeJs的CommonJS模块规范
    js 动画
    【THUPC 2018】赛艇
    【CF528D】Fuzzy Search
    【UR #6】懒癌
    【HNOI 2019】JOJO
  • 原文地址:https://www.cnblogs.com/embrace-ly/p/10570052.html
Copyright © 2011-2022 走看看