Function Declaration 與 Function Expression 的差異

栏目: JavaScript · 发布时间: 7年前

内容简介:Function Declaration 與 Function Expression 寫法看似相等,但 Function Declaration 會 Hoisting,而 Function Expression 不會。ECMAScript 5ECMAScript 2015

Function Declaration 與 Function Expression 寫法看似相等,但 Function Declaration 會 Hoisting,而 Function Expression 不會。

Version

ECMAScript 5

ECMAScript 2015

Function Declaration

console.log(sum(1, 2));

function sum(x, y) {
  return x + y;
}

使用 Function Declaration 定義 sum() ,雖然定義在 console.log() 下方,但依然能夠執行。

Function Declaration 與 Function Expression 的差異

Function Expression

console.log(sum(1, 2));

const sum = (x, y) => x + y;

sum() 改用 Function Expression 方式,看起來完全一樣,但卻無法執行。

Function Declaration 與 Function Expression 的差異

Why ?

原因在於 Function Declaration 會 Hoisting,所以儘管 sum() 定義在 console.log() 之後,但執行前會先 Hoisting 到最前面,所以仍然可以正常執行。

但 Function Expression 則不會 Hoisting,所以 sum() 必須定義在 console.log() 之前才能執行。

Conclusion

  • Function Declaration 看似與 Function Expression 一樣,都是定義 function,但卻有 Hoisting 的差異

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

计算机程序设计艺术卷1:基本算法(英文版.第3版)

计算机程序设计艺术卷1:基本算法(英文版.第3版)

Donald E.Knuth / 人民邮电出版社 / 2010-10 / 119.00元

《计算机程序设计艺术》系列著作对计算机领域产生了深远的影响。这一系列堪称一项浩大的工程,自1962年开始编写,计划出版7卷,目前已经出版了4卷。《美国科学家》杂志曾将这套书与爱因斯坦的《相对论》等书并列称为20世纪最重要的12本物理学著作。目前Knuth正将毕生精力投入到这部史诗性著作的撰写中。想了解本书最新信息,请访http://www-cs-faculty.stanford.edu/~knut......一起来看看 《计算机程序设计艺术卷1:基本算法(英文版.第3版)》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具