Javascript中暂停功能的实现

来源:互联网 发布:投票刷票软件 编辑:程序博客网 时间:2024/05/21 17:15
 
  1. <script language="javascript">
  2. /*Javascript中暂停功能的实现
  3. Javascript本身没有暂停功能(sleep不能使用)同时 vbscript也不能使用doEvents,故编写此函数实现此功能。
  4. javascript作为弱对象语言,一个函数也可以作为一个对象使用。
  5. 比如:
  6. function Test(){
  7. alert("hellow");
  8. this.NextStep=function(){
  9.   alert("NextStep");
  10. }
  11. }
  12. 我们可以这样调用 var myTest=new Test();myTest.NextStep();
  13. 我们做暂停的时候可以吧一个函数分为两部分,暂停操作前的不变,把要在暂停后执行的代码放在this.NextStep中。
  14. 为了控制暂停和继续,我们需要编写两个函数来分别实现暂停和继续功能。
  15. 暂停函数如下:
  16. */
  17. function Pause(obj,iMinSecond){
  18. if (window.eventList==null) window.eventList=new Array();
  19. var ind=-1;
  20. for (var i=0;i<window.eventList.length;i++){
  21.   if (window.eventList[i]==null) {
  22.    window.eventList[i]=obj;
  23.    ind=i;
  24.    break;
  25.   }
  26. }
  27. if (ind==-1){
  28.   ind=window.eventList.length;
  29.   window.eventList[ind]=obj;
  30. }
  31. setTimeout("GoOn(" + ind + ")",iMinSecond); 
  32. }
  33. /*
  34. 该函数把要暂停的函数放到数组window.eventList里,同时通过setTimeout来调用继续函数。
  35. 继续函数如下:
  36. */
  37. function GoOn(ind){
  38. var obj=window.eventList[ind];
  39. window.eventList[ind]=null;
  40. if (obj.NextStep) obj.NextStep();
  41. else obj();
  42. }
  43. /*
  44. 该函数调用被暂停的函数的NextStep方法,如果没有这个方法则重新调用该函数。
  45. 函数编写完毕,我们可以作如下册是:
  46. */
  47. function Test(){
  48. alert("hellow");
  49. Pause(this,1000);//调用暂停函数
  50. this.NextStep=function(){
  51.   alert("NextStep");
  52. }
  53. }
  54. </script> 
原创粉丝点击