美文网首页WEB前端程序开发程序员
WEB前端学习:ES6块级作用域的概念详解

WEB前端学习:ES6块级作用域的概念详解

作者: web前端小辰 | 来源:发表于2018-06-01 22:06 被阅读50次

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中新增的变量声明方式letconst都是属于块级作用域。声明的变量只能在作用域内被访问,变量也不会被提升。那为什么变量不会被提升呢?

这里要引入一个新概念临时死区(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的块级作用域就和大家介绍到这里。

相关文章

  • let 和 const

    一、JS中的块级作用域 ES6之前JS不支持块级作用域在ES6之前,JS是没有块级作用域这个概念的,只有全局作用域...

  • ES6分享会总结

    学到的内容 ES6的块级作用域 1. 块级作用域的概念 2. ES6允许在块级作用域内声明函数 3. 函数在块级作...

  • WEB前端学习:ES6块级作用域的概念详解

    Web前端开发工程师是一个很新的职业,是从事Web前端开发工作的工程师。主要进行网站开发,优化,完善的工作。网页制...

  • ES6小知识

    块级作用域 概念:在ES6中,凡是{}包裹的代码都是块级作用域,凡是在块级作用域中用let const声明的变量都...

  • js 作用域链 和 原型链

    作用域链 js拥有全局作用域(window)、函数作用域、块级作用域(es6)。块级作用域是es6开始才拥有的,因...

  • JS基础知识(2) -- 作用域和作用域链

    作用域 作用域就是变量与函数的可访问范围 全局作用域 函数作用域 ES6块级作用域 ES5没有块级作用域,ES6有...

  • js 作用域

    js 作用域主要有:全局作用域和局部作用域,es5之前没有块级作用域,es6有了块级作用域 何为块级作用域,块级作...

  • ECMAScript6基础学习教程(二)块级作用域

    ES6出现之前,只有函数可以形成作用域。而ES6中新增了块级作用域概念。 let和const命令可以构成一个块级作...

  • 你真的懂let和const吗?

    块级作用域 在ES6之前我们脑海里应该只存在全局作用域和函数级作用域,没有块级作用域。那么为什么要引入块级作用域呢...

  • ES6语法--let和const

    1:let和const:作用域,全局作用域,函数作用域以及块级作用域(es6)。 let声明的变量只在块级作用域内...

网友评论

    本文标题:WEB前端学习:ES6块级作用域的概念详解

    本文链接:https://www.haomeiwen.com/subject/ocqcsftx.html