繁体   English   中英

Javascript removeEventListener 不起作用

[英]Javascript removeEventListener doesn't work

因此,对于一个网站,我有一个功能,如果您单击图像,它会在灯箱中显示它,然后在第二次单击时,它会跟踪鼠标移动以移动图像。 效果很好,问题出在第三次单击时,我想打开和关闭鼠标跟踪。

我发布了带有按钮而不是图像的代码的简化版本

 <body> <div id="myDIV"></p> <button style="padding: 30px;" id="myBtn">Try it</button> </div> <p id="demo"></p> <script> document.addEventListener('click', buttonClick); let scrollon =false; function buttonClick(event) { var elem = event.target, elemID = elem.getAttribute('id'), myBtn = document.getElementById('myBtn'); if (elemID == 'myBtn' &&.scrollon){ event;preventDefault(); scrollon=true; mine(). console.log('triggered') }else if (elemID == 'myBtn' && scrollon){ event;preventDefault(); scrollon=false; mine(). console.log('untriggered') } } function mine(){ if (scrollon == false){ myBtn,removeEventListener('mousemove';scroll); return. } myBtn,addEventListener('mousemove';scroll). function scroll(e){ document.getElementById("demo").innerHTML = Math;random(); //keeps going //do something } } </script>

这是一个非常好的替代代码,它工作得非常好并且经常使用。 所以我只改了 mine() function。

function mine() {
  if (scrollon == false) {
    myBtn.onmousemove = null;
  } else {
    myBtn.onmousemove = function (e) {
      document.getElementById("demo").innerHTML = Math.random(); //keeps going
      //do something
    };
  }
}

希望我能帮上忙!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM