`
libran
  • 浏览: 188279 次
  • 性别: Icon_minigender_1
  • 来自: 天津
文章分类
社区版块
存档分类
最新评论

Javascript中暂停功能(sleep)的实现

阅读更多
 
 
  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. 我们可以这样调用 var myTest=new Test();myTest.NextStep(); 
  11. 我们做暂停的时候可以吧一个函数分为两部分,暂停操作前的不变,把要在暂停后执行的代码放在this.NextStep中。 
  12. 为了控制暂停和继续,我们需要编写两个函数来分别实现暂停和继续功能。 
  13. 暂停函数如下: 
  14. */ 
  15. function Pause(obj,iMinSecond){ 
  16. if (window.eventList==null) window.eventList=new Array(); 
  17. var ind=-1; 
  18. for (var i=0;i<window.eventList.length;i++){ 
  19.   if (window.eventList[i]==null) { 
  20.    window.eventList[i]=obj; 
  21.    ind=i; 
  22.    break
  23.   } 
  24. if (ind==-1){ 
  25.   ind=window.eventList.length; 
  26.   window.eventList[ind]=obj; 
  27. setTimeout("GoOn(" + ind + ")",iMinSecond); 
  28. /* 
  29. 该函数把要暂停的函数放到数组window.eventList里,同时通过setTimeout来调用继续函数。 
  30. 继续函数如下: 
  31. */ 
  32. function GoOn(ind){ 
  33. var obj=window.eventList[ind]; 
  34. window.eventList[ind]=null
  35. if (obj.NextStep) obj.NextStep(); 
  36. else obj(); 
  37. /* 
  38. 该函数调用被暂停的函数的NextStep方法,如果没有这个方法则重新调用该函数。 
  39. 函数编写完毕,我们可以作如下册是: 
  40. */ 
  41. function Test(){ 
  42. alert("hellow"); 
  43. Pause(this,1000);//调用暂停函数 
  44. this.NextStep=function(){ 
  45.   alert("NextStep"); 
  46. </script> 
原文地址:http://harrison2010.iteye.com/blog/181561   作者:harrison2010
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics