首頁 > web前端 > js教程 > 主體

javascript如何實現暫停功能

PHPz
發布: 2018-09-28 16:26:29
原創
2983 人瀏覽過

這篇文章主要介紹了javascript如何實現暫停功能,,Javascript本身沒有暫停功能,同時vbscript也不能使用doEvents,故編寫此函數實現此功能, 需要的朋友可以參考下,具體如下:

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影片教學

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