[英]How to make event listener to change a variable inside javascript code?
[英]Change value of a variable inside a timer event Javascript
我正在增加計時器內的變量值,它也在按鈕onClick事件內。
setInterval(function () {
document.getElementById('z_in').addEventListener('click', function () {
zoom_level = 1;
}, false);
document.getElementById('z_out').addEventListener('click', function () {
zoom_level = 3;
}, false);
document.getElementById('rotate').addEventListener('click', function () {
angle = angle + 10;
}, false);
Find(db, minLon, maxLon, minLat, maxLat, zoom_level, angle, stage, layer, i);
i++;
//angle = 0;
console.log();
}, 1000);
在這里,角度在每個循環中增加的不是太多而不是十乘十。這個問題的原因是什么?
如果僅在計時器啟用時才需要偵聽器,則可以使用以下方法:
var timer, i = 0, zoom_level = 1, angle = 0;
var z_in_el = document.getElementById('z_in');
var z_out_el = document.getElementById('z_out');
var rotate_el = document.getElementById('rotate');
function zoomIn(){
zoom_level = 1;
}
function zoomOut(){
zoom_level = 3;
}
function rotate(){
angle += 10;
}
function startTimer(){
addListeners();
timer = window.setInterval(function(){
i++;
Find(db, minLon, maxLon, minLat, maxLat, zoom_level, angle, stage, layer, i);
console.log(i, zoom_level, angle);
}, 1000);
}
function stopTimer(){
removeListeners();
window.clearInterval(timer);
}
function addListeners(){
z_in_el.addEventListener("click", zoomIn, false);
z_out_el.addEventListener("click", zoomOut, false);
rotate_el.addEventListener("click", rotate, false);
}
function removeListeners(){
z_in_el.removeEventListener("click", zoomIn, false);
z_out_el.removeEventListener("click", zoomOut, false);
rotate_el.removeEventListener("click", rotate, false);
}
使用startTimer()
設置間隔或使用stopTimer()
刪除間隔。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.