DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JS實現程序暫停與繼續功能代碼解讀
JS實現程序暫停與繼續功能代碼解讀
編輯:關於JavaScript     
下面代碼用JS實現了程序的暫停與繼續
復制代碼 代碼如下:
<script type="text/javascript">
/*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;i<window.eventList.length;i++){
if (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");
}
}
</script>
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved