let、const和var的区别
let、const和var的区别
var
- 存在变量提升 即变量可以在声明之前调用,值为
undefined
。 - 可以重复声明。
- 在函数中使用var声明变量的时候,该变量是局部的;对于声明在任何函数外的变量来说是全局的。
let
- 不存在变量提升,let声明变量前,该变量不能使用(暂时性死区)。
- let命令所在的代码块内有效,在块级作用域内有效。
- let不允许在相同作用域中重复声明,注意是相同作用域,不同作用域有重复声明不会报错。
const
- 不存在变量提升。
- 存在块级作用域。
- 同一作用域不允许重复声明变量。
- const声明一个只读的常量。一旦声明,常量的值就不能改变。const并不是变量的值不能改动,而是变量指向的内存地址所保存的数据不得改动。例如,在引用内容是对象的情况下,这意味着可以改变对象的内容。
变量提升和函数提升
在ES6之前,js是没有块级作用域,只有两种作用域
- 全局作用域
- 函数作用域
什么是没有块级作用域?
1 | var i=1; |
变量a是声明在if的{}里,但在js里面,因为没有块级作用域,所以此时的变量a的作用域是全局作用域。
什么是变量提升?
在我们的js中,代码的执行时分两步走的,1、解析 2、一步一步执行
那么变量提升就是变量声明会被提升到作用域的最顶上去,也就是该变量不管是在作用域的哪个地方声明的,都会提升到作用域的最顶上去。
1 | console.log(a);// undefined |
看几个例子:
1 | var a=10;// 全局变量:任何一个地方都可以访问,包括函数内部 |
再看一个例子:
1 | var a=1; |
什么是函数提升?
函数声明式,会将函数的声明和定义一起提升到作用域的最顶上去。
1 | fn();// 可正常调用 |
如果是这种写法:函数表达式声明的函数,相当于变量提升,如果使用const或let,则无法提升。
1 | fn();// 可正常调用 |
优先级
1 | console.log(fn);// ƒ fn(){} |
最后的总结:
1:所有的声明都会提升到作用域的最顶上去。
2:同一个变量只会声明一次,其他的会被忽略掉。
3:函数声明的优先级高于变量声明的优先级,并且函数声明和函数定义的部分一起被提升。
函数传参的一道题
1 | let a = { |
作用域链
1 | // var a |
隐式声明
1 | function change() { |
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Leslie Waong!
评论