ES6入门:let、const、 var区别及注意事项

ES6入门:let、const、 var区别及注意事项

一、let、const
1、用来声明变量或声明常量
2、let 代替 var,声明变量;const 声明常量,为了那些一旦初始化就不希望重新赋值的情况设计的
3、var、let声明的就是变量,变量一旦初始化之后,还可以重新赋值
4、const 声明的就是常量,常量一旦初始化,就不能重新赋值了,否则就会报错

var username = 'Alex';
let age = 18;
const sex = 'male';
console.log(username, age, sex);

二、const注意事项

1、使用 const 声明常量,一旦声明,就必须立即初始化,不能留到以后赋值

const sex = 'male';

2、const 声明的常量,允许在不重新赋值的情况下修改它的值

基本数据类型
const sex = 'male';
sex = 'female';    //报错,基本数据类型不可以

引用数据类型
const person = { username: 'Alex' };
// person = {};   //报错
person.username = 'ZhangSan';
console.log(person);       //{username:"ZhangSan"}

三、let、const、var的区别
1、重复声明:已经存在的变量或常量,又声明了一遍,var 允许重复声明,let、const 不允许

var a = 1;

var a = 2;
console.log(a);    //2
let a = 1;

let a = 2;
console.log(a);    //报错

function func(a) {   //在这里a已经以参数的形式存在了
  let a = 1;
}
func();   //报错

2、变量提升:var 会提升变量的声明到当前作用域的顶部,let、const 不存在变量提升

console.log(a);
var a = 1;

相当于
var a;
console.log(a);
a = 1;
console.log(a);  

letconst 不存在变量提升
console.log(a);
let a = 1;
//养成良好的编程习惯,对于所有的变量或常量,做到先声明,后使用

3、只要作用域内存在 let、const,它们所声明的变量或常量就自动“绑定”这个区域,不再受到外部作用域的影响,let、const 存在暂时性死区,var不存在

let a = 2;
function func() {
	console.log(a);
	let a = 1;
}
func();    //报错,出现let自动绑定,执行时,不能去外部作用域寻找
let b = 1;
function func() {
  console.log(b);
}
func();   //1,执行函数时,内层找不到,就可以去外层找

4、window 对象的属性和方法:全局作用域中,var 声明的变量,通过 function 声明的函数,会自动变成 window 对象的属性或方法,let、const 不会

var/function
var age = 18;
function add() {}
console.log(window.age);   //18
console.log(window.add === add);   //true

let/const
let age = 18;
const add = function () {};
console.log(window.age);   //undefined
console.log(window.add === add); //false

5、块级作用域
1、var 没有块级作用域

for (var i = 0; i < 3; i++) {
  // console.log(i);   //0,1,2
}
console.log(i); //3

2、let/const 有块级作用域

for (let i = 0; i < 3; i++) {
  // console.log(i);  //0,1,2
}
console.log(i);    //报错
//出了块级作用域就被销毁了,在全局范围内找不到了

补充:作用域链
在这里插入图片描述
作用域链:内层作用域->外层作用域->…->全局作用域

举例块级作用域
{}
for(){}
while(){}
do{}while()
if(){}
switch(){}
  • 6
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

萏语

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值