変数を設定してタイマーを停止できるようにするには本当に必要ですか?このような関数を呼び出させることでそれを実行できますか?
var TimerModule = (function(){
var timerHandle;
var startTimer = function(fnc, interval){
if(timerHandle){
//error, timer already running
return;
}
timerHandle = window.setInterval(fnc, interval);
};
var stopTimer = function(){
window.clearInterval(timerHandle);
timerHandle = null;
};
return {
start:startTimer,
stop:stopTimer
};
}());
TimerModule.start(function(){
alert("Hieee");
}, 1000);
window.setTimeout(function(){
TimerModule.stop();
}, 5000);
それ以外の場合、このようなsomethignは働くだろう:それは代わりに、間隔のsetTimeoutメソッドを使用し、実行しているがfalseの場合、タイムアウトはリセットされません
var defaults = {
callback: function() {
alert("hi");
},
crossfadeTime: 1000,
easing: 'linear',
running: 'true' // Here is where I would like the user to send a parameter
// to invoke a different result. i.e. 'false' => clearing
// the timer. Such as...
};
var timer;
var timerFunction = function() {
if (!defaults.running) {
return;
}
defaults.callback();
timer = setTimeout(timerFunction, 1000);
};
//start the timer
timerFunction();
window.setTimeout(function() {
defaults.running = false;
},5000);
。まさに問題が何であるか
var defaults = {
callback: function() {
alert("hi");
},
crossfadeTime: 1000,
easing: 'linear',
running: 'true',
callbackHandle: null
};
var timer;
var timerFunction = function() {
if (!defaults.running) {
window.clearInterval(defaults.callbackHandle);
defaults.callbackHandle = null;
}
defaults.callback();
};
//start the timer
defaults.callbackHandle = window.setInterval(timerFunction,1000);
window.setTimeout(function() {
defaults.running = false;
},5000);
:あなたは死んでセットがするsetIntervalを使用している場合は
が、これはトリックを行いますか! –
私は、タイマーを停止する関数を呼び出す文字列を渡すことによって、ユーザーがタイマーを終了できるようにします。すなわち、(ユーザ)実行中: '偽' => clearInterval(タイマー); – Romelus