1. let i = 0
    2. for(i = 0; i<6; i++){
    3. setTimeout(()=>{
    4. console.log(i)
    5. },0)
    6. }
    7. //结果打印6个6.

    settimeout是异步执行,0ms后往任务队列里面添加一个任务,
    只有主线上的全部执行完,才会执行任务队列里的任务,
    当主线执行完成后,i是6,所以此时再去执行任务队列里的任务时,i全部是6了。

    打印6个6,是因为:
    每一次for循环的时候,setTimeout都执行一次,
    但是里面的函数没有被执行,而是被放到了任务队列里面,等待执行,
    for循环了6次,就放了6次,当主线程执行完成后,才进入任务队列里面执行。

    1. for(let i = 0; i<6; i++){
    2. setTimeout(()=>{
    3. console.log(i)
    4. },0)
    5. }
    6. //结果打印0,1,2,3,4,5

    for循环头部的let不仅将i绑定到for循环块中,
    它也将其重新绑定到 循环体的每一次迭代 中,确保上一次迭代结束的值重新被赋值。

    setTimeout里面的function()属于一个新的域,
    没有通过 let 定义的变量是无法传入到这个函数执行域中的,
    而通过使用 let 来声明块变量,这时候变量就能作用于这个块,
    所以 function就能使用 i 这个变量了;

    这个匿名函数的参数作用域 和 for参数的作用域 不一样。