好吧,首先我应该问一下这是否依赖于浏览器.
我已经读过,如果找到一个无效的令牌,但代码段在该无效令牌之前有效,则在令牌之前插入分号(如果前面有换行符).
但是,由分号插入引起的错误引用的常见示例是:
return
_a+b;
Run Code Online (Sandbox Code Playgroud)
..它似乎不遵循这个规则,因为_a将是一个有效的标记.
另一方面,分解调用链按预期工作:
$('#myButton')
.click(function(){alert("Hello!")});
Run Code Online (Sandbox Code Playgroud)
有没有人对规则有更深入的描述?
您可能知道,ECMAscript会尝试变聪明,并且如果您没有明确地编写分号,则会自动插入分号.简单的例子
function foo() {
var bar = 5
return bar
}
Run Code Online (Sandbox Code Playgroud)
仍将按预期工作.但如果你依赖它,有一些警告.如果我们像这样重写那个函数
function foo() {
var bar = 5
return
{
bar: bar
}
}
Run Code Online (Sandbox Code Playgroud)
..这个函数现在会返回,undefined因为解释器会在return语句之后插入那个分号(这就是为什么你总是应该在一行语句的同一行上加上大括号的原因).
但是,了解所有这些我现在想知道,如下所述的声明在浏览器和版本之间是多么安全return
function foo() {
var a = true,
b = true,
c = false;
return a
&& b
&& c;
}
Run Code Online (Sandbox Code Playgroud)
我刚刚return statement在生产环境中写过类似的东西.仅仅因为我知道ECMAscript的"问题"对分号插入不太明智我现在想知道,如果该代码100%工作.在我对FF/Chrome/IE(最新版本)的第一次测试中,这似乎完全没问题,但它真的如此吗?
如果除了该行中的语句之外还有其他内容,自动分号插入是否会"唤醒" return?任何人都可以提供有关此实现级别的详细信息
javascript specifications ecmascript-5 automatic-semicolon-insertion