请考虑以下代码.
<!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>
解决方法:
在(函数b(){});内部,函数是函数表达式而不是函数声明(只有被挂起的函数声明).您可能会看一下var functionName = function() {} vs function functionName() {}的差异.
标签:javascript,hoisting 来源: https://codeday.me/bug/20190529/1180101.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。