javascript中setTimeout函数使用案例

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值