首頁 > web前端 > js教程 > javascript暫停功能如何實現

javascript暫停功能如何實現

王林
發布: 2021-10-26 15:49:39
原創
4117 人瀏覽過

實作javascript暫停功能的方法:【function sleep(obj,iMinSecond){ if (window.eventList==null) window.eventList=new Array(); var ...】。

javascript暫停功能如何實現

本文操作環境:windows10系統、javascript 1.8.5、thinkpad t480電腦。

我們知道javascript本身是沒有暫停功能的(sleep不能使用),而且vbscript也不能使用doEvents,因此小編打算自己手寫一個暫停函數。

提示:javascript作為弱物件語言,一個函數也可以當作一個物件使用。

例如:

function Test(){
 alert("hellow");
 this.NextStep=function(){
 alert("NextStep");
 }
}
登入後複製

我們可以這樣呼叫:

var myTest=new Test();myTest.NextStep();
登入後複製

我們做暫停的時候可以把一個函數分成兩部分,暫停操作前的不變,把要在暫停後執行的程式碼放在this.NextStep中。

為了控制暫停和繼續,我們需要寫兩個函數來分別實現暫停和繼續功能。

暫停函數如下:   

<script language="javascript"> 
  function sleep(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"); 
   sleep(this,3000);//调用暂停函数 
   this.NextStep=function(){ 
   alert("NextStep"); 
   } 
  } 
Test(); 
  </script>
登入後複製

推薦學習:javascript影片教學

#

以上是javascript暫停功能如何實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板