zoukankan      html  css  js  c++  java
  • 原生JS元素怎么取消事件

    关于原生JS元素怎么取消事件,有3种方式

     方法1:removeEventListener

    案例:

    <body>

    <div id="myDIV"> div 元素添加了  onmousemove 事件句柄,在你移动鼠标时会显示随机数。

         <p>点击按钮移除 DIV 的事件句柄。</p>

         <button onclick="removeHandler()" id="myBtn">点我</button>

    </div>

    <p id="demo"></p>

    <script>

    document.getElementById("myDIV").addEventListener("mousemove", myFunction);

    function myFunction()

    {

        document.getElementById("demo").innerHTML = Math.random();

    }

    function removeHandler()

    {

        document.getElementById("myDIV").removeEventListener("mousemove", myFunction);

    }

    </script>

    </body>

    原生JS里面的方法很少,所以换一种思路,在方法里面进行判断

    方法2:通过function里面的判断状态,然后return false

    案例:

    var state=1;

    document.getElementById("myBtn").addEventListener("click", function(){

    if(state==0){

    return false

    }else{

        alert(“caca”);

             state=0;

    }
       });

    方法3:通过function的判断状态,然后在方法里面再次添加此事件,覆盖事件后,然后再return false

    案例:

    var state=1;

    document.getElementById("myBtn").addEventListener("click", function(){

    if(state==0){

    document.getElementById("myBtn") .addEventListener("click", function() {return false;});

    }else{

           alert(“caca”);

                state=0;

    }
       });

  • 相关阅读:
    坦克大战
    java多线程应用场景
    java中的多线程(资料)
    设置线程名
    线程名称的设置及取得
    java调试
    文件上传细节处理
    Servlet生命周期
    java的动态绑定与静态绑定
    Mysql 连接池调用完成后close代理方法引出的设计模式
  • 原文地址:https://www.cnblogs.com/ranyonsue/p/7285531.html
Copyright © 2011-2022 走看看