欢迎来到福编程网,本站提供各种互联网专业知识!

JavaScript实现Sleep函数的代码

发布时间:2007-03-04 作者: 来源:转载
大家知道,JavaScript中没有内置我们常用的sleep()函数,只有定时器setTimeout()和循环定时器setInterval()

但是,这两个函数是异步的,在计时的过程中它们后面的代码还是会继续执行。那就自己来写个sleep()函数吧,网上也流传了一些实现方法,不过我发现下面这个方法简单易懂而且实用,所以在这里分享给大家:

复制代码 代码如下:
console.log('start...');
console.log('now time: ' + Date(/d{10,10}/.exec(Date.now())));
function sleep(sleepTime) {
for(var start = Date.now(); Date.now() - start <= sleepTime; ) { }
}
sleep(5000); // sleep 5 seconds
console.log('end...');
console.log('end time: ' + Date(/d{10,10}/.exec(Date.now())));

如果大家的程序对sleep()函数的精确度不那么高的话,使用这个函数是个不错的选择

下面这个是复杂些的,需要的朋友也可以参考一下:
复制代码 代码如下:
functionSleep(obj,iMinSecond)
{
if(window.eventList==null)
window.eventList=newArray();
varind=-1;
for(vari=0;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);
}
functionGoOn(ind)
{
varobj=window.eventList[ind];
window.eventList[ind]=null;
if(obj.NextStep)obj.NextStep();
elseobj();
}
functionTest()
{
alert("sleep");
Sleep(this,100);
this.NextStep=function()
{
alert("continue");
}
}

相关推荐