用Javascript实现Sleep暂停功能代码

 更新时间:2010年09月03日 21:42:56   作者:  
ie和firefox都可以使用,有兴趣可以试试
复制代码 代码如下:

<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);
}
function GoOn(ind)
{
var obj=window.eventList[ind];
window.eventList[ind]=null;
if (obj.NextStep) obj.NextStep();
else obj();
}


function Test()
{
alert("sleep");
Sleep(this,10000);
this.NextStep=function()
{
alert("continue");
}
}

Test();
//-->
</SCRIPT>

下面是别的网友写的代码
复制代码 代码如下:

<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 + ")",1000);
}
/*
该函数把要暂停的函数放到数组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>

相关文章

  • JavaScript实现动态网页飘落的雪花

    JavaScript实现动态网页飘落的雪花

    这篇文章主要为大家详细介绍了JavaScript实现动态网页飘落的雪花,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • js Array对象的扩展函数代码

    js Array对象的扩展函数代码

    有时候我们需要对js的array对象扩展一些功能,这里简单介绍下,方便需要的朋友
    2013-04-04
  • uni-app如何页面传参数的几种方法总结

    uni-app如何页面传参数的几种方法总结

    这篇文章主要介绍了uni-app如何页面传参数的几种方法总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • 初学JavaScript_03(ExtJs Grid的简单使用)

    初学JavaScript_03(ExtJs Grid的简单使用)

    Ext JS Grid的简单使用:(从土豆的文档中学到)
    2008-10-10
  • 微信小程序模板template简单用法示例

    微信小程序模板template简单用法示例

    这篇文章主要介绍了微信小程序模板template简单用法,结合实例形式分析了微信小程序模板template的功能、简单使用方法及相关操作注意事项,需要的朋友可以参考下
    2018-12-12
  • js Array.slice的8种不同用法示例

    js Array.slice的8种不同用法示例

    这篇文章主要给大家介绍了关于js Array.slice的8种不同用法,文中通过示例代码介绍的非常详细,对大家学习或者使用js 具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • 第一次接触Bootstrap框架

    第一次接触Bootstrap框架

    这篇文章主要为大家详细介绍了Bootstrap框架,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • javascript数据结构之串的概念与用法分析

    javascript数据结构之串的概念与用法分析

    这篇文章主要介绍了javascript数据结构之串的概念与用法,简单讲述了串的概念、功能并结合实例形式分析了基于javascript实现串的遍历、比较、查找等相关操作技巧,需要的朋友可以参考下
    2017-04-04
  • 5个书写JavaScript代码的坏习惯,看看你中枪了没?

    5个书写JavaScript代码的坏习惯,看看你中枪了没?

    这篇文章主要介绍了5个书写JavaScript代码的坏习惯,看看你中枪了没?,本文指出了你没有使用命名空间、变量定义的东一个西一个、Javascript的变量范围、Javascript的面向对象、new关键字等问题,需要的朋友可以参考下
    2014-11-11
  • 使用js获取url中的参数并返回一个对象方式

    使用js获取url中的参数并返回一个对象方式

    这篇文章主要介绍了使用js获取url中的参数并返回一个对象方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01

最新评论