详解javascript中的变量提升和函数提升
1在js中只有两种作用域
a:全局作用域
b:函数作用域
在ES6之前,js是没有块级作用域。
首先来解释一下什么是没有块级作用域?
所以此时 是可以打印输出变量a的值。
2:什么是变量提升?
在我们的js中,代码的执行时分两步走的,1、解析 2、一步一步执行
那么变量提升就是变量声明会被提升到作用域的最顶上去,也就是该变量不管是在作用域的哪个地方声明的,都会提升到作作用域的最顶上去。
那么上面这种写法其实等价于下面这种写法:
看几个例子:
把上面的例子稍作改动:
结果就会大不一样,
再看一个例子:
3:什么是函数提升?
输出的结果是:
注意:函数声明式,会将函数的声明和定义一起提升到作用域的最顶上去。
如果是这种写法:函数表达式声明的函数
例子:
输出的结果是:
最后的总结:
1:所有的声明都会提升到作用域的最顶上去。
2:同一个变量只会声明一次,其他的会被忽略掉。
3:函数声明的优先级高于变量申明的优先级,并且函数声明和函数定义的部分一起被提升。
相关文章
深入理解JavaScript系列(30):设计模式之外观模式详解
这篇文章主要介绍了深入理解JavaScript系列(30):设计模式之外观模式详解,外观模式(Facade)为子系统中的一组接口提供了一个一致的界面,此模块定义了一个高层接口,这个接口值得这一子系统更加容易使用,需要的朋友可以参考下2015-03-03JavaScript学习笔记整理_setTimeout的应用
下面小编就为大家带来一篇JavaScript学习笔记整理_setTimeout的应用。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-09-09javascript学习笔记(二十) 获得和设置元素的特性(属性)
javascript学习笔记之获得和设置元素的特性(属性)介绍,学习js的朋友可以参考下2012-06-06
最新评论