2017-03-05 175 views
0

問題:嗨,我正在處理一個番茄醬JS問題。當sessionTime倒計時到零時,我遇到了從sessionTime切換到breakTime的問題。在兩個setInterval函數之間切換

可能的解決方案:我試過方法(startPomodoro(),startPomodoroTwo()),但都沒有工作。

var countdown; 

var model = { 
    sessionTime: { seconds: 10, isFinished: false}, 
    breakTime: { seconds: 5, isFinished: false}, 

    timer: function(obj){ 
    console.log(obj.seconds); 
    var self = this; 
    countdown = setInterval(function() { 
     obj.seconds--; 
     console.log(obj.seconds); 
     if(obj.seconds <= 0){ 
     obj.isFinished = true; 
     clearInterval(countdown); 
     return; 
     } 
    },500); 
    }, 

    startPomodoro: function(){ 
    this.timer(this.sessionTime) 
    this.timer(this.breakTime) 
    }, 

    startPomodoroTwo: function(){ 
    if(this.sessionTime.isFinished === false){ 
    this.timer(this.sessionTime) 
    } else if (this.breakTime.isFinished === false && this.sessionTime.isFinished === true){ 
    this.timer(this.breakTime) 
    } else { 
    console.log("Finish Pomo"); 
    } 
    } 
} 
  1. startPomodoro(),它只是倒計時sessionTime和課間同時

  2. startPomodoroTwo(),這工作,但我需要執行的函數三次這是不是我想要。

+0

pomodoro js是什麼?同時請點擊'''''snippet編輯器並給我們一個[mcve] – mplungjan

回答

1

嘗試爲活動的數組:

var activities = [ 
    {name: 'session', duration: 10}, 
    {name: 'break', duration: 5} 
]; 
var currentActivity = 0; 

然後切換活動當定時器完成。

function startActivity() { 
    console.log(activities[currentActivity]); 
    var duration = activities[currentActivity].duration; 
    var timer = setInterval(function() { 
    duration--; 
    if (!duration) { 
     currentActivity = (currentActivity + 1) % activities.length; 
     clearInterval(timer); 
     startActivity(); 
    } 
    }, 1000); 
} 

嘗試不修改活動對象。您的代碼會改變引用對象,這意味着您必須在完成活動時將秒數重置爲10或5。

+0

謝謝,我們的代碼可以解決我的問題。 –