ES6新特性:(转载)
https://www.jianshu.com/p/287e0bb867ae
1:变量声明 const和let
在ES6之前,我们都是用var关键字声明变量。无论声明在何处,都会被视为声明在函数的最顶部(不在函数内即在全局作用于的最顶部),这就是函数变量提升
let表示变量,const表示常量,let和const都是块级作用域。说白了{}大括号内的代码即为let和const的作用域
let作用域在它所在当前代码块,但不会被提升到当前函数的最顶部
const常量,设置之后不可再修改。如果是一个对象,对象的值可以修改
面试题一道:
var data = [];
for(var k = 0; k < 3; k++){
data[k] = function(){ return k; };
}
alert(data[0]());
在这段代码中,执行data[0]()
时,调用函数return k赋值给data[k],
在这个函数作用域中没有定义k,因此向上搜索找到了全局变量k。
由于每次循环更改的都是同一个空间的k,当循环执行到K=3,由于看<3不成立循环里面的代码不执行,
但是k所在空间的值已经为3,因此当调用data[0]()
时,return K执行后所赋的值就是3.
(function(){
//code
})()
定义完成后立即执行
2:模板字符串
现在可以使用 console.log("hello${}");
3:箭头函数