第一个是声明过程:

var:
遇到有var的作用域,在任何语句执行器都已经完
成了声明和初始化,也就是变量提升并且拿到
undefined的原因。
let:
解析器进入一个块级作用域,发现let关键字,变
量只是先完成声明,并没有到初始化那一步。如果此
时在作用域提前访问,会报错 xx is not defined,这就
是暂时性死区的由来。等到解析到有let那一行时,才
会进入初始化阶段。如果let那一行是赋值操作,则初
始化和赋值同时进行。
const和let一样。

第二个是内存分配:

var:
会直接在栈内存里预分配内存空间,然后等到实
际语句执行时,再存储对应的变量,如果传的是引用
类型,则在堆内存里开辟一个内存空间存储实际内
容,栈内存会存储一个指向堆内存的指针
let:
不会在栈内存里预分配内存空间,而且在栈内存
分配变量的时候,会检查,如果有相同变量名存在就
会报错
const:
不会分预配内存空间,栈内存分配变量时也会
做同样的检测。const存储的变量是不可修改的,所以
对于基本类型来说无法修改定义的值,对于引用类型
来说无法修改栈内存里分配的指针,但是可以修改指
针指向的对象里面的属性

第三个是变量提升:

let只是创建过程中提升,初始化过程并没有提升,所
以会产生暂时性死区。
var的创建和初始化过程都提升了,所以赋值前访问会
得到undefined

最后修改:2020 年 11 月 12 日
如果觉得我的文章对你有用,请随意赞赏