let 和 const

一,作用域

1.在es5中只存在全局作用域函数作用域

2.在es6中新增了块级作用域

二,letconst

一, let
1.let声明的变量具有块级作用域,let声明的变量只在块级作用域内以及其子块作用域有效,出了这些作用域生命周期结束,因此,let 声明的变量不属于全局对象window的属性。

{let a=1;
  {let a=2;a=3;console.log(a)}//a=3;
console.log(a)}//a=1
{let a=1;{a=2};console.log(a)}//a=2

2.在同一个块级作用域内不能重复声明相同的变量,可在其子块作用域声明相同的变量,这两个是不同的变量,虽然名字相同。

二,const
1.const声明的变量具有块级作用域,const用于声明一个常量,不能被修改。
2.注意,假如用const声明一个引用类型数据,那么该数据里的元素可以被修改,因为引用类型数据是由一个指针指着的,修改数据元素,不会改变指针指着的地址。

{
	const a ='come on'
	a=1 //报错
	
	const o={k:1}
	o.change='add a element'
	console.log(o) //{k:1,change:'add a element'}
	o="string"  // 报错 Assignment to constant variable
	console.log(o)
}

三,变量提升

1.letconst声明的变量都不存在变量提升。

四,暂时性死区

1.在一个块里面如果使用了letconst,那么存在暂时性死区,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。

{
	var a =10
	{ 
		a=3
		console.log(a) // Cannot access 'a' before initializatio
		let a=8
	}
}

五,letconst的作用

1.letconst定义的变量具有块作用域,可以避免全局污染。在同一个块使用let声明的变量不能重名,这可以保证我们不会覆盖掉已定义的核心变量。

2.const保证了我们不希望被修改的变量不会被修改。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值