DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> js基於setTimeout與setInterval實現多線程
js基於setTimeout與setInterval實現多線程
編輯:關於JavaScript     

本文實例講述了js基於setTimeout與setInterval實現多線程的方法。分享給大家供大家參考,具體如下:

javascript無法實現線程阻塞(sleep),原因是因為sleep涉及系統調用。js出於安全考慮是不允許系統調用的。

如果一定要實現語句繼續執行就只能用while(1)空轉的方法消耗CPU,判斷到了時間就break。不過這個方法也不是真正sleep。

只執行一次的定時器

<script>
//定時器使用的是異步的方式運行的
function hello(){
  alert("hello");
}
//使用方法名字執行方法
var t1 = window.setTimeout(hello,1000);
var t2 = window.setTimeout("hello()",3000);//使用字符串執行方法
window.clearTimeout(t1);//去掉定時器
</script>

重復執行的定時器

<script>
function hello(){
  alert("hello");
}
//重復執行某個方法
var t1 = window.setInterval(hello,1000);
var t2 = window.setInterval("hello()",3000);
//去掉定時器的方法
window.clearInterval(t1);
</script>

問題:

如果在一個頁面中有兩個方法都是在頁面加載完成之後執行的,但是實際運行的結果不能按照自己想象的先後順序執行,該如何解決呢?

解決方法:

可以在onload方法中添加一個定時器,設置一個定時器,“延遲”一段時間之後再運行,這樣就可以人為區分頁面加載運行方法的先後順序了。

更多關於JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved