1、提出问题
为什么如下代码会打印 6 个 6
let i = 0
for(i = 0; i<6; i++){
setTimeout(()=>{
console.log(i)
},0)
}
执行结果:
提示:
- setTimeout()定时器
window.setTimeout(调用函数,[延迟的毫秒数]);
- setTimeout()是一个回调函数,需要等待时间,时间到了才去调用这个函数。
- 他类似于异步任务。
- JS是一种单线程语言,即同一时间只能做一件事。
- JS的执行机制:首先判断是同步还是异步,同步任务在主线程执行,当有异步任务的时候,提交给对应的异步进程处理,异步任务完毕,推入任务队列中。当主线程执行完毕,查询任务队列,取出一个任务,推入到主线程处理。重复该动作(事件循环)。
以上代码执行过程:
- 声明一个变量i,并赋值i=0
- 判断i<6
- 如果i<6则进入循环,遇到setTimeout()定时器(表示过一会再输出i)
- 执行i++,