84669 人が学習中
152542 人が学習中
20005 人が学習中
5487 人が学習中
7821 人が学習中
359900 人が学習中
3350 人が学習中
180660 人が学習中
48569 人が学習中
18603 人が学習中
40936 人が学習中
1549 人が学習中
1183 人が学習中
32909 人が学習中
for(var i=0; i< 3;i++){ setTimeout(function() { console.log(i); }, 0); }
输出结果是3,3,3 能否详细解释一下执行过程?
所有的异步操作都是等同步操作执行完毕开始执行。哪怕是setTimeout的间隔时间设置为0for循环是同步的,每一次循环都会创造一个定时器并改变i的值。当循环执行完毕的时候i的值已经是3了,这个时候setTimeout才会开始执行,所以这时候输出的是3
所有的异步操作都是等同步操作执行完毕开始执行。
哪怕是setTimeout的间隔时间设置为0
for循环是同步的,每一次循环都会创造一个定时器并改变i的值。当循环执行完毕的时候i的值已经是3了,这个时候setTimeout才会开始执行,所以这时候输出的是3