答案 0 :(得分:5)
AFAIK,函数一直是函数作用域。我认为ES6中可能有些变化
确实如此:在ES2015之前,规范并没有涵盖块内声明的功能。支持它们是允许的扩展,但不是规范的一部分。
因此,规范必须跳过箍,特别是在浏览器的松散模式下。
在严格模式下,您将在兼容引擎上找到函数声明确实是块作用域的:
"use strict";
function test() {
if (true) {
function foo() {
console.log("foo called");
}
}
try {
foo(); // ReferenceError
} catch (e) {
console.log("Error: " + String(e));
}
}
test();

在兼容的JavaScript引擎(例如任何最新版本的Chrome中的V8或任何最新版本的Firefox中的SpiderMonkey)中,您将获得ReferenceError
上面的内容。