函数声明和函数表达式可以互换使用吗?

时间:2017-12-17 02:34:05

标签: javascript node.js function functional-programming

我正在学习Javascript中的函数,但对函数声明和函数表达的使用感到困惑。

假设我有以下代码:

function callFunction(fn) {
  fn();
}

// function expression
var sayHello1 = function() {
  console.log("Hello World!");
}

// function declaration
function sayHello2() {
  console.log("Hello World!");
}

callFunction(sayHello1); // Hello World!
callFunction(sayHello2); // Hello World!

我们可以很容易地看到,将sayHello1(函数表达式)和sayHello2(函数声明)传递给callFunction(fn)时,两者都生成相同的输出Hello World!

是否有任何真实案例我必须仅使用函数声明/函数表达式,或者我可以一直使用可互换

非常感谢!

1 个答案:

答案 0 :(得分:2)

他们都有自己的用例。函数声明是 hoisted 到脚本的顶部,可以在定义出现之前调用,而函数表达式只能在声明后调用。

sayHello1(); // Won't work since variable expression is created after call
sayHello2(); // Will work since function declarations are hoisted

var sayHello1 = function() {
  console.log("Hello World!");
}

function sayHello2() {
  console.log("Hello World!");
}

命名函数表达式对递归调用很有用:

var sayHello1 = function sayHelloFunc() {
  if (/* something */) {
    sayHelloFunc()
  }
}