ES6(块级作用域)
我们都知道在javascript里是没有块级作用域的,而ES6添加了块级作用域,块级作用域能带来什么好处呢?为什么会添加这个功能呢?那就得了解ES5没有块级作用域时出现了哪些问题。
ES5在没有块级作用域的情况下出现的问题:
一。在if或者for循环中声明的变量会泄露成全局变量
for(var i=0;i<=5;i++){ console.log("hello"); } console.log(i); //5
二。内层变量可能会覆盖外层变量
var temp = new Date(); function f(){ console.log(temp); if(false){ var temp = "hello"; } } f(); //undefined
不管最后是否执行if语句,都会输出undefined,因为temp会提升到函数顶部,因此覆盖了外部的变量temp。
上一篇介绍的let和const命令,它们所声明的变量只在所在的代码块内有效,即为js添加了块级作用域。
【1】允许块级作用域任意嵌套;
{{{let tmp = "hello world"}}}
【2】外层作用域无法读取内层作用域的变量;
{{{ {let tmp = "hello world";} console.log(tmp); //error }}}
【3】内层作用域可以定义外层作用域的同名变量
{{{ let tmp = "hello world"; {let tmp = "hello world";} }}}
【4】函数本身的作用域在其所在的块级作用域之内。
function f(){ console.log("outside"); } (function(){ if(false){ function f(){ console.log("inside"); } } f(); }());
这段代码如果是在ES5中运行,那么会输出inside,因为在ES5中,函数会提升到作用域的顶部,如果是在ES6中运行,则会输出outside,因为在ES6中函数无法提升,所以访问到的f()是外层的f()。
【5】在ES5中,因为没有块级作用域,获得广泛运用的是立即执行函数。现在ES6增加了块级作用域,那么立即执行函数就不再必要了。
//立即执行函数 (function(){ var temp = "hello world"; }()); //块级作用域 { var temp = "hello world"; }
【6】在严格模式下,函数只能在顶级作用域和函数内声明,在if代码块和循环代码块下的声明都会报错。