javascript中setTimeout函数使用案例

来源:互联网 发布:网络电视怎么安装 编辑:程序博客网 时间:2024/05/19 01:08
alert("start");var t = true;window.setTimeout(function(){   t = false;}, 1000);while(t){}alert("end");
死循环原因解释

事件触发线程,当一个事件被触发时该线程会把事件添加到待处理队列的队尾,等待JS引擎的处理。这些事件可来自JavaScript引擎当前执行的代码块如setTimeOut、也可来自浏览器内核的其他线程如鼠标点击、AJAX异步请求等,但由于JS的单线程关系所有这些事件都得排队等待JS引擎处理。(当线程中没有执行任何同步代码的前提下才会执行异步代码


setTimeout(function() {console.log(123);var s = new Date();var n = s.getTime();console.log(n);}, 0);for (var i = 0; i < 50; i++) {console.log(new Date().getTime());};

扩展资料

http://www.infoq.com/cn/articles/js_multithread

http://www.suchso.com/projecteactual/Javascript-setTimeout-timer.html

http://www.ibm.com/developerworks/cn/web/1105_chengfu_jsworker/

https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/setTimeout


0 0
原创粉丝点击