码迷,mamicode.com
首页 > 编程语言 > 详细

javascript函数篇三、函数声明提升

时间:2019-10-19 23:28:23      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:初始   java   function   方式   cti   efi   执行环境   表达   def   

变量提升想必大家都比较熟悉了,那么什么是函数声明提升呢?
首先我们来了解下常用的两种函数定义方式:
1. 函数声明
2. 函数表达式

下面来看下两种方式定义函数。
函数声明语法定义函数

function fn (n) {
    return n * 2
} 

函数表达式定义函数

var fn = function (n) {
    return n * 2
}

*那么两种方式定义函数有什么区别呢?*
**对于函数声明与函数表达式两种定义函数的方式,解析器会率先读取函数声明,并使其在执行任何代码之前可用,*这个过程叫函数声明提升*,而函数表达式则是在真正执行到他所在的代码行,才会被解释执行。**
看下例子就明白了:

fn(2)
function fn (n) {
    return n * 2
}

上面的代码完全可以正常运行,因为在代码开始执行之前,解析器已经进行了函数声明提升,将函数声明添加到执行环境中。
相反下面的代码则会报错:

fn(2)
var fn = function (n) {
    return n * 2
}

因为,函数声明位于一个赋值语句中,实际上,这里进行的是**变量提升**,也就是变量fn被提升到顶部,但并未被初始化为函数对象,在执行fn(2)的时候,fn变量为undefined,代码执行到这里就会报错,不会继续往下执行了。


总结:
函数声明提升指,当用函数声明语法定义函数时,解析器会在代码执行之前读取并将函数声明添加到执行环境,使其在执行任何代码之前可用。

 

javascript函数篇三、函数声明提升

标签:初始   java   function   方式   cti   efi   执行环境   表达   def   

原文地址:https://www.cnblogs.com/youyang-2018/p/11706269.html

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