使用JavaScript如何提升变量和函数

发布时间:2020-11-05 16:21:42 作者:Leah
来源:亿速云 阅读:126

今天就跟大家聊聊有关使用JavaScript如何提升变量和函数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

1在js中只有两种作用域

a:全局作用域

b:函数作用域

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

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

使用JavaScript如何提升变量和函数

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

2:什么是变量提升?

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

在预解析阶段:首先会在全局作用域内,js解析器会找所有的 var 、function 、参数,并提前到当前作用域的最顶上去(变量的赋值操作不会提前,还在原来的地方),此时并没有执行代码。

然后再开始一行一行执行代码。遇到了函数调用,于是进入到函数作用域内,又开始分两步骤走,1、预解析 2、一步一步执行。以此类推。

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

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

使用JavaScript如何提升变量和函数

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

使用JavaScript如何提升变量和函数

看几个例子:

使用JavaScript如何提升变量和函数

把上面的例子稍作改动:

结果就会大不一样,

使用JavaScript如何提升变量和函数

再看一个例子:

使用JavaScript如何提升变量和函数

3:什么是函数提升?

使用JavaScript如何提升变量和函数

输出的结果是:

使用JavaScript如何提升变量和函数

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

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

使用JavaScript如何提升变量和函数

例子:

使用JavaScript如何提升变量和函数

输出的结果是:

使用JavaScript如何提升变量和函数

最后的总结:

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

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

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

看完上述内容,你们对使用JavaScript如何提升变量和函数有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

推荐阅读:
  1. js变量提升和函数提升
  2. 什么是JavaScript变量提升

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

javascript 变量 函数

上一篇:ProxyVue与Vue Object.defineProperty实现双向数据绑定的方法

下一篇:连接Docker容器的方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》