Web前端开发工程师是一个很新的职业,是从事Web前端开发工作的工程师。主要进行网站开发,优化,完善的工作。网页制作是Web 1.0时代的产物,那时网站的主要内容都是静态的,用户使用网站的行为也以浏览为主。
给你学习路线,html-css-js-ajax-jq-html5-css3-bootstrap-vue.js-node.js-react.jd
ES6小册子的第一章要和大家分享块级作用域的概念,了解 let 和 const 两种声明变量方式的特点。
小编推荐一个学Web前端的学习裙【 五四七,三零二,三八三 】,无论你是大牛还是小白,是想转行还是想入行都可以来了解一起进步一起学习!裙内有开发工具,很多干货和技术资料分享!
1.让人摸不清头脑的变量提升
在ES5中我们使用 var 来声明变量,无论变量实际在哪里声明的,都会提升到当前作用域顶部声明。变量提升是前端面试必考的知识点之一,为此还有一些精心设计的题目,常常让人搞不清楚。举个栗子:
console.log(test); //1var test = function(){ var test = "aaa"; console.log(test); }console.log(test);//2test();//3
请问1,2,3分别的输出是什么?
前端开发人员需要花费时间来熟悉理解JavaScript的变量提升机制,变量提升还可能导致一些难以发现的bug。
2.块级作用域
ES6中新增的变量声明方式let
和const
都是属于块级作用域。声明的变量只能在作用域内被访问,变量也不会被提升。那为什么变量不会被提升呢?
这里要引入一个新概念临时死区(temporal dead zone)。通过let或const声明的变量会放到临时死区,在执行过变量声明的语句后才能被访问。如果在声明语句前访问就会报错。举个栗子:
console.log(testLet);let testLet = "aaa";
image
由此也要注意,必须要先声明变量再使用。我一直认为这是一个好习惯。ES6中如果访问未被声明的变量都会报错,typeOf
操作也会报错。
3.let
let 的用法和 var 一样,let声明的变量可以被再次修改。但是同一变量不能重复声明。
let param = "";param = "test";let param = ""; //error
小编推荐一个学Web前端的学习裙【 五四七,三零二,三八三 】,无论你是大牛还是小白,是想转行还是想入行都可以来了解一起进步一起学习!裙内有开发工具,很多干货和技术资料分享!
image
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 );
image
可以看到var生命的全局变量已经覆盖了window的属性,然而let声明的变量可以正常作为全局变量使用但没有覆盖window的属性。
由此来说let要比var安全很多,现在ES6已经成为前端开发的主要标准了,建议大家也及早切换到ES6上。更加方便,快速,高效,简洁,安全,优势太多太多。
4.const
const的用法和let一样,需要先声明再引用,不能重复声明同一变量。const与let的不同点在于const声明的变量不能修改。
举个栗子:
const test = "22222";test = "";
小编推荐一个学Web前端的学习裙【 五四七,三零二,三八三 】,无论你是大牛还是小白,是想转行还是想入行都可以来了解一起进步一起学习!裙内有开发工具,很多干货和技术资料分享!
image
但是const声明的对象可以修改属性。
const testObj = {a:'1111'};testObj.a = "222";console.log(testObj.a); // 222
关于ES6的块级作用域就和大家介绍到这里。
网友评论