码迷,mamicode.com
首页 > Web开发 > 详细

js中的变量提升和函数提升

时间:2018-05-24 00:08:08      阅读:263      评论:0      收藏:0      [点我收藏+]

标签:变量提升 函数提升 作用域

1在js中只有两种作用域

a:全局作用域

b:函数作用域

在ES6之前,js是没有块级作用域。

首先来解释一下什么是没有块级作用域?

技术分享图片

所以此时 是可以打印输出变量a的值。

2:什么是变量提升?

在我们的js中,代码的执行时分两步走的,1、解析 2、一步一步执行

那么变量提升就是变量声明会被提升到作用域的最顶上去,也就是该变量不管是在作用域的哪个地方声明的,都会提升到作作用域的最顶上去。

技术分享图片

那么上面这种写法其实等价于下面这种写法:

技术分享图片

看几个例子:

技术分享图片

把上面的例子稍作改动:

结果就会大不一样,

技术分享图片

再看一个例子:

技术分享图片

3:什么是函数提升?

技术分享图片

输出的结果是:

技术分享图片

注意:函数声明式,会将函数的声明和定义一起提升到作用域的最顶上去。

如果是这种写法:函数表达式声明的函数

技术分享图片

例子:

技术分享图片

最后的总结:

1:所有的声明都会提升到作用域的最顶上去。

2:同一个变量只会声明一次,其他的会被忽略掉。

3:函数声明的优先级高于变量申明的优先级,并且函数声明和函数定义的部分一起被提升。

js中的变量提升和函数提升

标签:变量提升 函数提升 作用域

原文地址:http://blog.51cto.com/11871779/2119667

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!