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 其实是不同的变量。
* /