首頁 >web前端 >js教程 >JS實現程序暫停與繼續功能代碼解讀_javascript技巧

JS實現程序暫停與繼續功能代碼解讀_javascript技巧

WBOY
WBOY原創
2016-05-16 17:20:331106瀏覽

下面程式碼用JS實作了程式的暫停與繼續

複製程式碼 程式碼如下:


程式碼如下:



程式碼如下:



程式碼如下:



/*Javascript中暫停功能的實作
Javascript本身沒有暫停功能(sleep不能使用)同時vbscript也不能使用doEvents,故編寫此函數實作此功能。
javascript作為弱物件語言,一個函數也可以當作一個物件使用。
例如:
function Test(){
alert("hellow");
this.NextStep=function(){
alert("NextStep");
}
}
我們可以這樣呼叫var myTest=new Test();myTest.NextStep();


我們做暫停的時候可以吧一個函數分成兩部分,暫停操作前的不變,把暫停後執行的程式碼放在this.NextStep中。
為了控制暫停和繼續,我們需要寫兩個函數來分別實現暫停和繼續功能。
暫停函數如下:
*/
function Pause(obj,iMinSecond){
if (window.eventList==null) window.eventList=new Array();
var ind= -1;
for (var i=0;iif (window.eventList[i]==null) {
window.eventList[i]= obj;
ind=i;
break;
}
}

if (ind==-1){
ind=window.eventList.length;
window.eventList[ind]=obj;
}
setTimeout("GoOn(" ind ")",iMinSecond);
}
/*
函數把要暫停的函數放到陣列window.eventList裡,同時透過setTimeout來呼叫繼續函數。


繼續函數如下:
*/


function GoOn(ind){
var obj=window.eventList[ind];
window .eventList[ind]=null;
if (obj.NextStep) obj.NextStep();
else obj();
}
/*
函數呼叫被暫停的函數的NextStep方法,如果沒有這個方法則重新呼叫該函數。


函數寫完畢,我們可以作如下冊是:
*/ function Test(){ alert("hellow"); Pause(this, 3000);//呼叫暫停函數this.NextStep=function(){ alert("NextStep"); } }
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn