gpt4 book ai didi

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

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:26:32 25 4
gpt4 key购买 nike

考虑以下代码。

<!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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com