JavaScript编程精解系列——简化函数提升
小作 2018-03-07 来源 :网络 阅读 451 评论 0

摘要:本系列JavaScript编程精解将给大家系统的讲解一些基础知识,看完这系列文章会让你对JavaScript入门有更加清晰的概念。

本系列JavaScript编程精解将给大家系统的讲解一些基础知识,看完这系列文章会让你对JavaScript入门有更加清晰的概念。

 

为了理解函数提升,让我们从以下代码开启我们的学习之旅:

 

console.log(foo);

var foo = 9;

应该输出什么呢?

 

在任何其他编程语言中,这里的输出将会是reference error。但是,在JavaScript中,你将得到undefined作为输出。为什么?因为JavaScript会提升变量到执行上下文的顶部。执行上下文可以是声明变量的函数,也可以是声明变量的JavaScript文件。所以,让我们用函数重写上面的代码片段:

 

function abc() {

    console.log(foo);

    var foo = 9;

}

abc();

这里,变量“foo”提升到函数abc执行上下文的顶部;这意味着你可以在声明之前访问foo。简而言之,无论何时你声明一个变量,JavaScript解释器都可以将其分成两个语句:

 

声明一个变量。

赋值。

 

变量foo被提升到函数abc的执行上下文的顶部,因此当你在声明之前使用它时,你会得到“undefined”作为输出。

 

请记住,使用let语句声明的变量不会被提升到执行上下文的顶部。

 

现在你知道JavaScript中的变量是如何被提升的了,接下来让我们来探讨JavaScript中的函数提升。在JavaScript中,可以通过两种方式来创建函数:

 

作为声明而创建的函数。

作为表达式而创建的函数。

作为声明或语句创建的函数作为一个整体提升到执行上下文的顶部。但是,作为表达式创建的函数会像变量一样提升。

 

为了说明这一点,让我们创建一个作为语句的函数:

 

foo();

function foo() {

    console.log("hello");

}

在上面的代码中,如果你在函数创建之前使用函数,那么你会得到hello的输出。发生这种情况的原因是,作为语句创建的函数会当作一个整体被提升到执行上下文的顶部。

 

无论何时创建作为语句的函数,都可以在函数创建之前使用该函数。因此,如果你在第5行创建作为语句的函数,那么你可以在第1-4行中使用该函数,因为函数语句会随函数主体一起提升到执行上下文的顶部。

 

函数语句会随函数主体一起提升到执行上下文的顶部。

 

函数表达式会像一个变量一样被提升到执行上下文的顶部。请看下面的代码:

 

foo();

var foo = function () {

    console.log("hello");

}


foo在执行上下文的顶部被声明为一个变量,然而,在变量foo中的函数赋值发生在第6行,也就是创建作为表达式函数的地方。所以,当你尝试执行上面的代码时,你会得到错误undefined is not a function

 

因此,你不能在函数表达式被创建之前使用函数表达式,因为只有函数声明会提升到顶部。

 

综上所述:

 

函数语句随函数主体一起被提升到执行上下文的顶部。你可以在函数创建之前使用作为语句创建的函数。

函数表达式在创建之前不能使用。只有声明部分会被提升,赋值发生在创建函数的那一行。


希望这篇文章可以帮助到你。总之,同学们,你想要的职坐标IT频道都能找到!

本文由 @小作 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    ICP许可  沪B2-20190160

站长统计