码迷,mamicode.com
首页 > 其他好文 > 详细

setTimeout的作用以及setTimeout延时0毫秒的作用

时间:2016-08-23 01:33:31      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:

以下代码输出的顺序是?

console.log(1);
setTimeout(function(){
console.log(2);
}, 0);
setTimeout(function(){
console.log(3);
}, 1000);
console.log(4);

答案是:

1
4
2
3

 

 

经常看到setTimeout延时0ms的javascript代码,感到很迷惑,难道延时0ms和不延时不是一个道理吗?后来通过查资料以及实验得出以下两个作用,可能还有作用我还不知道,希望得知的朋友在后面评论上不吝指出。
1、实现javascript的异步;
正常情况下javascript都是按照顺序执行的。但是我们可能让该语句后面的语句执行完再执行本身,这时就可以用到setTimeout延时0ms来实现了。
如: 
alert(1); 
setTimeout("alert(2)", 0); 
alert(3); 
虽然延时了0ms,但是执行顺序为:1,3,2 
这样就保证setTimeout里面的语句在某一代码段中最后执行。 

setTimeout的作用以及setTimeout延时0毫秒的作用

标签:

原文地址:http://www.cnblogs.com/facial/p/5797696.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!