考虑以下代码。
<!DOCTYPE html>
<script>
console.log(a);
function a() {}
</script>
请注意,a
它似乎在定义之前已被访问。控制台输出是:(jsfiddle)
function a() {}
函数和变量名称是在任何其他代码运行之前定义的,因此 console.log 调用在这里起作用。这称为吊装。
但是如果函数被定义为函数调用中的参数,这不起作用。看看这段代码。
<!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>