|
但是,這兩個函數是異步的,在計時的過程中它們后面的代碼還是會繼續執行。那就自己來寫個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()函數的精確度不那么高的話,使用這個函數是個不錯的選擇
下面這個是復雜些的,需要的朋友也可以參考一下:
復制代碼 代碼如下:
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,100);
this.NextStep=function()
{
alert("continue");
}
}
JavaScript技術:JavaScript實現Sleep函數的代碼,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。