相关疑难解决方法(0)

JavaScript的自动分号插入(ASI)有哪些规则?

好吧,首先我应该问一下这是否依赖于浏览器.

我已经读过,如果找到一个无效的令牌,但代码段在该无效令牌之前有效,则在令牌之前插入分号(如果前面有换行符).

但是,由分号插入引起的错误引用的常见示例是:

return
  _a+b;
Run Code Online (Sandbox Code Playgroud)

..它似乎不遵循这个规则,因为_a将是一个有效的标记.

另一方面,分解调用链按预期工作:

$('#myButton')
  .click(function(){alert("Hello!")});
Run Code Online (Sandbox Code Playgroud)

有没有人对规则有更深入的描述?

javascript automatic-semicolon-insertion

400
推荐指数
5
解决办法
15万
查看次数

JavaScript空白语法错误

为什么这会导致return语句出现语法错误:

var FOO = (function($)
{
    return
    {      
        init: function()
        {

        }
    }
})(jQuery);
Run Code Online (Sandbox Code Playgroud)

然而,这不是:

var FOO = (function($)
{
    return {      
        init: function()
        {

        }
    }
})(jQuery);
Run Code Online (Sandbox Code Playgroud)

为什么会有区别?

javascript syntax formatting jquery whitespace

8
推荐指数
1
解决办法
1146
查看次数

难以理解分号插入

据此,如果出现以下情况,JavaScript将插入分号:

当程序包含正式语法不允许的标记时,如果(a)在该点有换行符,或(b)意外标记是右括号,则插入分号.(强调我的)

经典的例子是

return  //  <--- semicolon inserted there
{
   id: 12
};
Run Code Online (Sandbox Code Playgroud)

这让我相信自由立场{是无效的.然而,以下(无意义)代码警告2,没有错误

function foo() {
    var x = 1;
    {
        var y = 2; //yes, I know y has the same scope as x 
    }              //and that this is therefore pointless
    alert(y);
}
Run Code Online (Sandbox Code Playgroud)

为什么在第一个代码中将左大括号视为无效标记,这导致JavaScript插入分号,但是在第二个代码中开括号不被视为无效 - 正如没有错误的事实所证明的那样.

很明显,我的一个假设是错误的,我希望有人可以帮助我理解哪些.

javascript

3
推荐指数
1
解决办法
234
查看次数