[英]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.