javascript - 定义为函数调用参数的函数名称不会提升。为什么不?

标签 javascript hoisting

考虑以下代码。

<!DOCTYPE html>
<script>
  console.log(a);
  function a() {}
</script>

注意 a 似乎在定义之前就被访问了。控制台输出为:( jsfiddle )

function a() {}

函数和变量名称在任何其他代码运行之前定义,因此 console.log 调用在这里起作用。这叫做 hoisting .

但是如果函数被定义为函数调用中的参数,这将不起作用。看看这段代码。

<!DOCTYPE html>
<script>
  function a() {}
  a(function b() {});
  console.log(b);
</script>

请注意,函数 b 是在对 a 的调用中定义的。不是在闭包内部,而是在调用内部。控制台输出为:( jsfiddle )

Uncaught ReferenceError: b is not defined

我想知道为什么会这样。这是预期的行为吗?这在 Chrome 和 Firefox 中都会发生。

更新:这jsfiddle表明函数表达式中的名称在定义它们的范围内永远不可用。但是,名称是在函数本身的范围内定义的。这意味着命名函数表达式可以引用名称,但只能在函数内部引用。该名称还存储在函数的 name 参数中。

<!DOCTYPE html>
<script>
  console.log(a); // undefined
  var a = function b() {
    console.log(b); // function b() { … };
  };
  a(); // function b() { … };
  console.log(a); // function b() { … };
  console.log(a.name); // b
  console.log(b); // Uncaught ReferenceError: b is not defined
</script>

最佳答案

a(function b() {}); 中,该函数是一个函数表达式,而不是一个函数声明(只有被吊起)。你可以看看 var functionName = function() {} vs function functionName() {}为了区别。

关于javascript - 定义为函数调用参数的函数名称不会提升。为什么不?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14218779/

相关文章:

javascript - 为什么这个函数没有运行?

c# - 获取所有控件的值

javascript - Javascript 提升顺序详解

javascript - 吊装和可变范围

javascript - firebug 控制台不进行提升

javascript - JS引擎编译阶段的优先顺序

函数混淆中的javascript变量范围

javascript - 使用 AJAX 检查远程站点是否在线?

php - 如何将搜索结果拆分为页面?

javascript - 如何在 Javascript 中生成偏态随机数?