ES6(01 基础 let和const命令)

推荐学习地址:
http://es6.ruanyifeng.com

声明变量(6种方法)
ES5(2种):var命令和function命令
ES6(新添加4种):let命令、const命令、import命令和class命令

let 命令
1. 只在所在代码块中有效
2. 不存在变量提升
3. 暂时性死区
4. 不允许重复声明

const 命令
定义:该命令声明一个只读的常量,一旦声明就不能改变。
1. 只在所在代码块中有效
2. 不存在变量提升
3. 暂时性死区
4. 不允许重复声明
5. 声明时必须被赋值
本质:const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址不得改动。 const 声明的常量类似于指针,它指向某个引用,也就是说这个「常量」并非一成不变的。

var 命令
5. 在全局范围内都有效
6. 会发生”变量提升“现象

function命令
函数声明
ES5 规定,函数只能在顶层作用域和函数作用域之中声明,不能在块级作用域声明。
ES6 规定,块级作用域之中,函数声明语句的行为类似于let,在块级作用域之外不可引用。
针对ES6的浏览器
- 允许在块级作用域内声明函数。
- 函数声明类似于var,即会提升到全局作用域或函数作用域的头部。
- 同时,函数声明还会提升到所在的块级作用域的头部。

变量提升
即变量可以在声明之前使用,值为undefined

暂时性死区
如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。

作用域
ES5:全局作用域和函数作用域
ES6:块级作用域

块级作用域

  1. 外层代码块不受内层代码块的影响
  2. 允许块级作用域任意嵌套
  3. 外层作用域无法读取内层作用域的变量
  4. 内层作用域可以定义外层作用域的同名变量

顶层对象的属性
顶层对象:在浏览器环境指的是window对象,在Node指的是global对象

ES6规定,

  • 为了保持兼容性,var命令和function命令声明的全局变量,依旧是顶层对象的属性;
  • 另一方面规定,let命令、const命令、class命令声明的全局变量,不属于顶层对象的属性。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值