当前位置:网站首页>ES6简介及let、var、const区别
ES6简介及let、var、const区别
2022-08-03 20:04:00 【嘿………】
ECMAScript6
一、简介
1、什么是ES6?
- ES的全称是ECMAScript,它是由ECMA国际标准化组织,制定的一项脚本语言的标准化规范。
2、为什么使用ES6?
- 变量提升特性增加了程序运行时的不可预测性
- 语法过于松散,实现相同的功能,不同的人可能会写出不同的代码
二、let(ES6新增的用于声明变量的关键字)
(1)let声明的变量只在所处于的块级有效
//let关键字就是用来声明变量的
let a = 10;
console.log(a); //10
//使用let关键字声明的变量具有块级作用域
if(true){
let b = 10;
console.log(b); //10
}
console.log(b); //报错:b is not defined
//在一个大括号中使用let关键字声明的变量才具有块级作用域,var关键字是不具备这个特点的
if(true){
let a = 10;
var b = 20;
}
console.log(b); //20
console.log(a); //报错:a is not defined
//防止循环变量变成全局变量
for(var i = 0; i < 2; i++){ //使用var
}
console.log(i); //2
for(let i = 0; i < 2; i++){ //使用let
}
console.log(i); //报错:i is not defined
(2)不存在变量提升
//使用let关键字声明的变量没有变量提升
console.log(a); //报错:a is not defined
let a = 20;
(3)暂时性死区
//使用let关键字声明的变量暂时性死区
var num = 123;
if(true){
console.log(num); //报错:num is not defined
let num = 12;
}
三、 const(ES6新增的关键字)
作用:声明常量,常量就是值(内存地址)不能变化的量。
(1)具有块级作用域
//使用const关键字声明的常量具有块级作用域
if(true){
const a = 10;
console.log(a); //10
}
console.log(a); //a is not defined
(2)声明常量时必须赋值
//使用const关键字声明的常量必须赋初始值
const PI; //报错: Missing initializer in const declaration
const PI = 3.14;
(3)常量赋值后,值不能修改
//常量声明后值不可更改
const PI = 3.1415;
PI = 100; //报错:Assignment to constant variable 不能更改常量的值
const arr = [100,200];
arr[0] = "a";
arr[1] = "b";
console.log(arr); //['a','b']
arr = ['a','b']; //报错:Assignment to constant variable
四、let、const、var的区别
使用var声明的变量,其作用域为该语句所在的函数内,且存在变量提升现象。
使用let声明的变量,其作用域为该语句所在的代码块内,不存在变量提升。
使用const声明变量的是常量,在后面出现的代码中不能再修改该常量的值。
边栏推荐
猜你喜欢
RNA-ATTO 390|RNA-ATTO 425|RNA-ATTO 465|RNA-ATTO 488|RNA-ATTO 495|RNA-ATTO 520近红外荧光染料标记核糖核酸RNA
友宏医疗与Actxa签署Pre-M Diabetes TM 战略合作协议
盘点在线帮助中心对企业能够起到的作用
【leetcode】剑指 Offer II 009. 乘积小于 K 的子数组(滑动窗口、双指针)
友宏医疗与Actxa签署Pre-M Diabetes TM 战略合作协议
转运RNA(tRNA)甲基化修饰7-甲基胞嘧啶(m7C)|tRNA-m7G
149. The largest number on a straight line, and check the set
建模该从哪一步开始?给你分析,给零基础的你一些学习建议
【微信小程序2】事件传参与数据同步[03]
消除对特权账户的依赖使用Kaniko构建镜像
随机推荐
tRNA修饰2-甲基胞嘧啶(m2C)|tRNA修饰m2G (N2-methylguanosine)
622 设计循环队列——Leetcode天天刷【循环队列,数组模拟,双指针】(2022.8.2)
头条服务端一面经典10道面试题解析
LeetCode 899. 有序队列
消除对特权账户的依赖使用Kaniko构建镜像
倒计时2天,“文化数字化战略新型基础设施暨文化艺术链生态建设发布会”启幕在即
友宏医疗与Actxa签署Pre-M Diabetes TM 战略合作协议
php根据两点经纬度计算距离
node版本切换工具NVM以及npm源管理器nrm
1161 最大层内元素和——Leetcode天天刷【BFS】(2022.7.31)
那些年我写过的语言
LeetCode 952. Calculate Maximum Component Size by Common Factor
tensorflow-gpu2.4.1安装配置详细步骤
matplotlib画polygon, circle
涨薪5K必学高并发核心编程,限流原理与实战,分布式计数器限流
Go语言类型与接口的关系
Auto.js实现朋友圈自动点赞
【leetcode】剑指 Offer II 009. 乘积小于 K 的子数组(滑动窗口、双指针)
告诉你0基础怎么学好游戏建模?
【飞控开发高级教程4】疯壳·开源编队无人机-360 度翻滚