JS裡設定延遲:
使用SetInterval和設定延時函數setTimeout 很類似。 setTimeout 運用在延遲一段時間,再進行某項操作。
setTimeout("function",time) 設定一個逾時物件
setInterval("function",time) 設定一個逾時物件
SetInterval為自動重複,setTimeout不會重複。
clearTimeout(物件) 清除已設定的setTimeout物件
clearInterval(物件) 清除已設定的setInterval物件
使用計時器實作JavaScript的延期執行或重複執行
window物件提供了兩個方法來達到定時器的效果,分別是window.setTimeout()和window.setInterval。其中前者可以使一段程式碼在指定時間後運作;而後者則可以讓一段程式碼每過指定時間就執行一次。它們的原型如下:
window.setTimeout(expression,milliseconds);
window.setInterval(expression,milliseconds);
其中,expression可以是用引號括起來的一段程式碼,也可以是一個函數名,到了指定的時間,系統便會自動呼叫該函數,當使用函數名作為呼叫句柄時, 不能帶有任何參數;而使用字串時,則可以在其中寫入要傳遞的參數。兩個方法的第二個參數是milliseconds,表示延時或重複執行的毫秒數。下 面分別介紹兩種方法。
1. window.setTimeout方法
此方法可以延時執行一個函數,例如:
這段程式碼將讓頁面開啟5秒鐘後顯示對話框「hello」。其中最後一句也可以寫成:
window.setTimeout( "hello()",5000);
讀者可以體會它們的差別,在window.setInterval方法中也有這樣的性質。
如果在延遲期限到達之前取消延執行,可以使用window.clearTimeout(timeoutId)方法,該方法接收一個id,表示一個定時器。這個id是由setTimeout方法回傳的,例如:
程式碼如下:
}
複製程式碼
程式碼如下:
上面的程式碼僅用來說明怎樣取消一個定時執行。實際上在許多場合都需要用到setInterval方法,下面將設計一個秒錶,來介紹setInterval 函數的用途:該秒錶將包含兩個按鈕和一個用於顯示時間的文字方塊。當點選開始按鈕時開始計時,最小單位為0.01秒,此時再次點選按鈕則停止計時,文字方塊顯示 示經過的時間。另外一個按鈕用於將當前時間清零。其實作程式碼如下: 複製程式碼 程式碼如下:
New Document
7.4.3 給定時器呼叫傳遞參數
無論是window.setTimeout或window.setInterval,在使用函數名稱作為呼叫句柄時都不能帶參數,而在許多場合必須要帶參數,這就需要想方法解決。例如函數hello(_name),它用於針對使用者名稱顯示歡迎訊息:
複製程式碼
程式碼如下:
}
}
}
}
}
}
}
}
}
}
}
複製代碼
程式碼如下:
window.setTimeout(hello(userName),3000);
複製程式碼
程式碼如下:
window.setTimeout("hello(userName)",3000);
複製程式碼 程式碼如下:
setTimeout方法是定時程序,也就是在什麼時間以後做什麼。乾完了就拉倒。
setInterval方法則是表示間隔一定時間重複執行某操作。
JS裡設定延時:
使用SetInterval和設定延時函數setTimeout 很類似。 setTimeout 運用在延遲一段時間,再進行某項操作。
setTimeout("function",time) 設定一個逾時物件
setInterval("function",time) 設定一個逾時物件
SetInterval為自動重複,setTimeout不會重複。
clearTimeout(物件) 清除已設定的setTimeout物件
clearInterval(物件) 清除已設定的setInterval物件
若使用setTimeout實作setInerval的功能,就需要在執行的程式行中再設定時呼叫自己才已設定好設定自己。如果要清除計數器需要依照使用的方法不同,請呼叫不同的清除方法:
例如:
複製程式碼
程式碼如下:tttt=setTimeout('northsnow()',1000);
clearTimeout(tttt);
或:
或:
或:
複製程式碼
舉個例子:
{
window.clearTimeout(timer2);
>