3-2 常用的 es6 语法有哪些?var 怎么实现 let


常用的 es6 语法有哪些?

let, const, class, import, export, export default, Promise, async, await, for await, Object.values,Object.kes, array.form array.reduce ...

var 怎么实现 let?

// 结果输出10 个 10, why?
for (var i = 0; i < 10; i++) {
  setTimeout(function(){
    console.log(i);
  })
}
/**
 * 变量 i 是用 var 声明的,在全局范围内有效,所以全局中只有一个变量 i,当我们用 console.log(window.i) 来检验 i 时,发现 i 为10。每次循环时,setTimeout 定时器里面的 i 指的是全局变量 i ,而循环里的十个 setTimeout 是在循环结束后才执行,所以会输出十个 10
 *
 * /

利用函数作用域修改为每个 i 为独立作用域

for (var i = 1; i < 4; i++) {
  (function f(a) {
    setTimeout(function () {
      console.log(a);
    }, 1000);
  })(i);
}
/**
 * 利用 函数作用域,在每次函数执行过程,中,都将当前的值,传入,每一个函数执行,内部都会声明一个新的参数作用域变量a,每个函数内部的 a 其实是不同的变量。
 * /

相关