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

2023-11-30

考虑以下代码。

<!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 中都会发生这种情况。

UPDATE: This 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>

Inside a(function b() {});,该函数是函数表达式而不是一个函数声明(仅限悬挂的)。你可能会看看var functionName = function() {} vs function functionName() {}为了差异。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

定义为函数调用参数的函数名称不会被提升。为什么不? 的相关文章

随机推荐