即使在不同的浏览器中,此代码也始终有效:
function fooCheck() {
alert(internalFoo()); // We are using internalFoo() here...
return internalFoo(); // And here, even though it has not been defined...
function internalFoo() { return true; } //...until here!
}
fooCheck();
不过,我找不到任何关于它为何有效的参考资料。
我第一次在 John Resig 的演讲笔记中看到这一点,但只是提到了。那里或任何地方都没有对此问题的解释。
有人可以启发我吗?
The function
声明是神奇的,它会导致其标识符在执行其代码块*中的任何内容之前被绑定。
这与带有function
表达式,按正常的自上而下顺序计算。
如果您将示例更改为:
var internalFoo = function() { return true; };
它会停止工作。
函数声明在语法上与函数表达式完全分开,尽管它们看起来几乎相同并且在某些情况下可能不明确。
这记录在ECMAScript标准 https://www.ecma-international.org/publications/standards/Ecma-262.htm, 部分10.1.3。不幸的是,即使按照标准,ECMA-262 也不是一个非常可读的文档!
*:包含函数、块、模块或脚本。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)