ES6小册子的第一章要和大家分享块级作用域的概念,了解 let 和 const 两种声明变量方式的特点。
1.让人摸不清头脑的变量提升
在ES5中我们使用 var 来声明变量,无论变量实际在哪里声明的,都会提升到当前作用域顶部声明。变量提升是前端面试必考的知识点之一,为此还有一些精心设计的题目,常常让人搞不清楚。举个栗子:
console.log(test); //1
var test = function(){
var test = "aaa";
console.log(test);
}
console.log(test);//2
test();//3
请问1,2,3分别的输出是什么?
前端开发人员需要花费时间来熟悉理解JavaScript的变量提升机制,变量提升还可能导致一些难以发现的bug。
2.块级作用域
ES6中新增的变量声明方式<code>let</code>和<code>const</code>都是属于块级作用域。声明的变量只能在作用域内被访问,变量也不会被提升。那为什么变量不会被提升呢?
这里要引入一个新概念临时死区(temporal dead zone)。通过let或const声明的变量会放到临时死区,在执行过变量声明的语句后才能被访问。如果在声明语句前访问就会报错。举个栗子:
console.log(testLet);
let testLet = "aaa";
由此也要注意,必须要先声明变量再使用。我一直认为这是一个好习惯。ES6中如果访问未被声明的变量都会报错,<code>typeOf</code>操作也会报错。
3.let
let 的用法和 var 一样,let声明的变量可以被再次修改。但是同一变量不能重复声明。
let param = "";
param = "test";
let param = ""; //error
let属于块级作用域,在不同块级域中允许存在相同名称的变量。
let pa = "";
let test = function() {
let pa = "111";
}
在一般场景中,let完全可以替代var。如果你需要声明全局变量的话,可以把let声明放到作用域的顶部。这里还要说明一下声明全局变量时let或const相对于var的优势。
我们在使用var声明全局变量时有可能会不小心覆盖一个已存在的全局变量。但是let或const会在全局作用域下创建一个新的绑定,但是不会添加为全局对象的属性。这个确实很难理解,其中的深层原理我还没有去探究。还是举个栗子说明一下。
let testLet = "test";
console.log(testLet);
console.log("let: " + window.testLet);
var testVar = "testVar";
console.log(testVar);
console.log("var: " + window.testVar );
可以看到var生命的全局变量已经覆盖了window的属性,然而let声明的变量可以正常作为全局变量使用但没有覆盖window的属性。
由此来说let要比var安全很多,现在ES6已经成为前端开发的主要标准了,建议大家也及早切换到ES6上。更加方便,快速,高效,简洁,安全,优势太多太多。
4.const
const的用法和let一样,需要先声明再引用,不能重复声明同一变量。const与let的不同点在于const声明的变量不能修改。
举个栗子:
const test = "22222";
test = "";
但是const声明的对象可以修改属性。
const testObj = {a:'1111'};
testObj.a = "222";
console.log(testObj.a); // 222
关于ES6的块级作用域就和大家介绍到这里,欢迎大家给我留言。等待你的反馈~
ES6小册子帮你用最短的时间掌握前端开发的核心语言~