【系统学习ES6】第一节:新的声明方式
【系统学习ES6】
本专题旨在对ES6的常用技术点进行系统性梳理,帮助大家对其有更好的掌握。计划每周更新1-2篇,希望大家有所收获。
以前用ES5时,声明变量只能用var。ES6的出现,为我们带来了两种新的声明方式:let和const。我们可以先简单记忆:
var:声明全局变量let:声明局部变量const:声明常量
var声明
var在ES6里是用来声明全局变量的,我们先看一个简单的例子:
var a = "lemoncool";
console.log(a);
控制台输出了“lemoncool”。但这个例子不足以声明a是全局变量。我们继续声明一个函数,在函数体中看是否可以拿到函数外面声明的a。
var a = "lemoncool";
var testFun = function(){
console.log(a);
}
testFun();
控制台同样输出了“lemoncool”,说明函数中可以拿到外部声明的a,这可以说明var声明的变量确实是全局的。如果你觉得这个例子说服力还不够,那我们继续看。
var a = "lemoncool";
var testFun = function(){
a = '23';
}
testFun();
console.log(a);
此时控制台会输出多少呢?是"23"。我想,这个例子,足以说明var是全局声明的。
let 声明
我们试着用let再次执行上面的例子:
var b = "lemoncool";
var testFun = function(){
let b = '23';
}
testFun();
console.log(b);
函数执行后,再打印b,你觉得会输出多少呢?结果是此时输出的是"lemoncool"。为什么?
因为我们在函数里用通过let声明了 b,这时的 b ="23"只在函数作用域内有效,属于局部变量。外面的打印,拿不到函数的局部变量,所以拿不到"23"。
那如果我们只在函数体里声明b,外部的声明删掉,打印就会输出"23"么?
var testFun = function(){
let b = '23';
}
testFun();
console.log(b);

不好意思,报错了。不在外部声明,即使函数里声明再多花样,外部依然拿不到。
上面两个例子,说明了let声明的是局部变量。let声明的变量,只在区块内起作用,外部拿不到,也是不可以调用的。有关作用域问题,大家可以自行查阅资料深入了解。
所以let不会存在变量提升的bug,可以有效防止数据污染。同时,let不允许在相同作用域内,重复声明同一个变量。
在合理场景下,我们要努力去习惯用let代替var。
const 声明
在开发中,有些变量从声明后就不允许改变。这种变量叫常量。这时就需要用到const声明。
我们通过一个反例,看一段错误代码:
const c = "lemoncool";
c = 'hello';
console.log(c);
执行这段代码时,会报错。原因是const声明的变量不可改变。
const c = "lemoncool";
console.log(c); //"lemoncool"
const d; // SyntaxError: Missing initializer in const declaration
这段代码同样会报错, 意味着,const一旦声明必须初始化,否则会报错。
Q:const声明的变量初始化不允许再改变,是针对所有类型么?
A:答案是“否”,简单类型(数值 number、字符串 string 、布尔值 boolean),的确是这样。但是对于复杂类型(对象 object,数组 array,函数 function),const只能保证变量指针是固定的,至于指针指向的数据结构,是否发生变化,就有些无法控制。所以使用 const 声明复杂类型对象时要慎重。
暂时性死区
var temp = "lemoncool";
if (true) {
console.log(temp);
const temp = '123456';
}
你以为会输出“lemoncool”?NO,会报错。
ES6 明确规定,代码块内如果存在 let 或者 const,代码块会对这些命令声明的变量从块的开始就形成一个封闭作用域。 凡是在声明之前就使用这些变量,就会报错。
所以,在代码块内,使用let或const命令声明变量之前,该变量都是不可用的。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。
上面代码中,在const命令声明变量temp之前,都属于变量temp的“死区”。

到此,三种声明方式的使用方法及注意事项已梳理完毕。没有整理很细,因为细的知识点太多,不知从何说起。大家作为一个大纲,举一反三。
下一节我们会一起讨论【解构赋值】,感谢大家支持,希望大家在每一节中都有所得。
公棕号【前端便利贴】记录着一个程序媛的所见所得所想,分享日常技术笔记,内容覆盖了阅读、技术和个人思考~,关注公棕号更早获取更多文章。
觉得有用的话,小手点点【推荐】再走吖~~
【系统学习ES6】第一节:新的声明方式的更多相关文章
- 【系统学习ES6】第二节:解构赋值
[系统学习ES6] 本专题旨在对ES6的常用技术点进行系统性梳理,帮助大家对其有更好的掌握,希望大家有所收获. ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构.解构是一种打 ...
- 【系统学习ES6】新专题发布
我要发免费专题了,向下看 公众号和博客都有一阵没更新了,丢了一些粉儿,但是也很庆幸,时时还会有人关注.我并不是什么专业讲师,文章都是利用业余时间手工原创.在这里非常感谢各位的支持和厚爱. 这个月开始, ...
- ES6第二节:新的声明方式
通过上一节的环境搭建完成,接下来我们就可以愉快的探索ES6的新世界了!下面我们从新的声明方式开始: 在ES6里新加了两种声明方式:let 和 const,以前我们都是用var去作声明,接下来我们一一比 ...
- 学习HTML 第一节.小试牛刀
此贴并非教学,主要是自学笔记,所述内容只是些许个人学习心得的记录和备查积累,难以保证观点正确,也不一定能坚持完成. 如不幸到访,可能耽误您的时间,也难及时回复,贴主先此致歉.如偶有所得,相逢有缘,幸甚 ...
- 二.ES6新的声明方式
前言: 以前我们在声明时只有一种方法,就是使用var来进行声明,ES6对声明的进行了扩展,现在可以有三种声明方式了. 字面理解ES6的三种声明方式: var:它是variable的简写,可以理解成变量 ...
- ES6系列_2之新的声明方式
在ES5中我们在声明时只有一种方法,就是使用var来进行声明,ES6对声明的进行了扩展,现在可以有三种声明方式. (1)var:它是variable的简写,可以理解成变量的意思. (2)let:它在英 ...
- Vue快速学习_第一节
之前写CRM都是Django前后端一起写的,在大部分项目中实际上前后端是分离的,因此我们需要学习一个前端框架来进行前端页面的编写,这里选择了Vue进行学习,好了开始学习吧. 1.ES6部分知识点学习 ...
- python3网络爬虫系统学习:第一讲 基本库urllib
在python3中爬虫常用基本库为urllib以及requests 本文主要描述urllib的相关内容 urllib包含四个模块:requests——模拟发送请求 error——异常处理模块 pars ...
- [struts2学习笔记] 第一节 关于struts2的简单认知
本文地址:http://blog.csdn.net/sushengmiyan/article/details/40298287 官方文档:http://struts.apache.org/releas ...
随机推荐
- 【SQLite】SQLite文件突然变大怎么办?瘦身办法
使用VACUUM命令即可: VACUUM 命令通过复制主数据库中的内容到一个临时数据库文件,然后清空主数据库,并从副本中重新载入原始的数据库文件.这消除了空闲页,把表中的数据排列为连续的,另外会清理数 ...
- itools安装程序无法创建临时文件夹
做个记录: itools链接ios设备后,安装程序包时提示:无法创建临时文件夹 主要原因可能有以下几点 1.手机储存空间不足. 2.驱动组建被删除了,重启管理软件会自动跟新驱动. 解决办法:1.清除空 ...
- Java设计模式(5:设计模式的分类及工厂模式详解)
一.设计模式的分类 总的来说,设计模式可以分为三大类:创建型模式.结构型模式.行为型模式,具体如下图: 二.工厂模式 工厂模式分为简单工厂模式.工厂方法模式和抽象工厂模式.其中简单工厂模式并不属于23 ...
- 【题解】Luogu2915 [USACO08NOV]奶牛混合起来Mixed Up Cows
题目描述 Each of Farmer John's N (4 <= N <= 16) cows has a unique serial number S_i (1 <= S_i & ...
- NOIP模拟测试38「金·斯诺·赤」
金 辗转相减见祖宗 高精 #include<bits/stdc++.h> using namespace std; #define A 2000 #define P 1 #define N ...
- redis cluster如何支持pipeline
当我们要操作一批key时,可以通过 redis pipline 再执行完后一次性读取所有结果来较少网络传输的消耗: 很明显,这有个限制条件 => 这批key的执行必须在同一个连接上 当部署的re ...
- Linux命令大全之帮助命令及压缩命令
man(manual):帮助命令 help用于解释shell内部命令 格式:help shell内部命令 ls 命令 --help man 命令 info 命令 .zip .gz .bz ...
- matplotlib 并列条形图
1 绘制并列条形图,并在条形图上加标注 1.1 代码 from matplotlib import pyplot from matplotlib import font_manager import ...
- Java 设置Word文本框中的文字旋转方向
Word文档中可添加文本框,并设置文本框为横向文本排列或是纵向文本排列,或者设置文本框中的文字旋转方向等.通过Java程序代码,也可以实现以上文本框的操作.下面以Java代码示例展示具体的实现步骤.另 ...
- ES6、ES7的一些新特性
1.常见的就是let 和 const 命令 let 只在命令所在的代码块内有效 const声明一个只读的常量 2.变量的赋值 let [a, b, c] = [1, 2, 3]; 这样输出的话a=1, ...