js基于setTimeout與setInterval實現(xiàn)多線程
本文實例講述了js基于setTimeout與setInterval實現(xiàn)多線程的方法。分享給大家供大家參考,具體如下:
javascript無法實現(xiàn)線程阻塞(sleep),原因是因為sleep涉及系統(tǒng)調(diào)用。js出于安全考慮是不允許系統(tǒng)調(diào)用的。
如果一定要實現(xiàn)語句繼續(xù)執(zhí)行就只能用while(1)空轉的方法消耗CPU,判斷到了時間就break。不過這個方法也不是真正sleep。
只執(zhí)行一次的定時器
<script>
//定時器使用的是異步的方式運行的
function hello(){
alert("hello");
}
//使用方法名字執(zhí)行方法
var t1 = window.setTimeout(hello,1000);
var t2 = window.setTimeout("hello()",3000);//使用字符串執(zhí)行方法
window.clearTimeout(t1);//去掉定時器
</script>
重復執(zhí)行的定時器
<script>
function hello(){
alert("hello");
}
//重復執(zhí)行某個方法
var t1 = window.setInterval(hello,1000);
var t2 = window.setInterval("hello()",3000);
//去掉定時器的方法
window.clearInterval(t1);
</script>
問題:
如果在一個頁面中有兩個方法都是在頁面加載完成之后執(zhí)行的,但是實際運行的結果不能按照自己想象的先后順序執(zhí)行,該如何解決呢?
解決方法:
可以在onload方法中添加一個定時器,設置一個定時器,“延遲”一段時間之后再運行,這樣就可以人為區(qū)分頁面加載運行方法的先后順序了。
更多關于JavaScript相關內(nèi)容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結》、《JavaScript數(shù)據(jù)結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數(shù)學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
- 深入理解setTimeout函數(shù)和setInterval函數(shù)
- 快速掌握Node.js中setTimeout和setInterval的使用方法
- JavaScript中setTimeout和setInterval函數(shù)的傳參及調(diào)用
- JavaScript中SetInterval與setTimeout的用法詳解
- javascript中SetInterval與setTimeout的定時器用法
- Javascript中setTimeOut和setInterval的定時器用法
- JavaScript中停止執(zhí)行setInterval和setTimeout事件的方法
- js中的setInterval和setTimeout使用實例
- JavaScript SetInterval與setTimeout使用方法詳解
- setTimeout和setInterval的深入理解
- BOM系列第二篇之定時器requestAnimationFrame
- BOM系列第三篇之定時器應用(時鐘、倒計時、秒表和鬧鐘)
- BOM系列第一篇之定時器setTimeout和setInterval
相關文章
JS target與currentTarget區(qū)別說明
target在事件流的目標階段;currentTarget在事件流的捕獲,目標及冒泡階段。只有當事件流處在目標階段的時候,兩個的指向才是一樣的,而當處于捕獲和冒泡階段的時候,target指向被單擊的對象而currentTarget指向當前事件活動的對象(一般為父級)。2011-08-08
Javascript ParentNode和ChildNode接口原理解析
這篇文章主要介紹了Javascript ParentNode和ChildNode接口原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03
JavaScript實現(xiàn)獲取遠程的html到當前頁面中
今天做個項目,需要在當前的html頁面中引用一個遠程的html頁面,百度了一下,發(fā)現(xiàn)一個非常好用的代碼,這里分享給大家,有相同需求的小伙伴可以來看看2017-03-03

