- <script language="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,1000);//調用暫停函數
- this.NextStep=function(){
- alert("NextStep");
- }
- }
- </script>
原文地址:http://harrison2010.javaeye.com/blog/181561 作者:harrison2010