本文實例講述了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程序設計有所幫助。