相关疑难解决方法(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"语句的奇怪行为

我是JavaScript的新手,刚开始用JavaScript进行一些更严肃的开发.我有很多乐趣来实现Module模式.真正让我发疯的一件事是"回归"陈述的行为.如果你写的话,这是一个很大的不同

Test = ( function()
{
    var message = "Hello World!";

    return
    {
        // Does not work
        printTest: function() { window.alert(message); }
    };
}());
Run Code Online (Sandbox Code Playgroud)

要么

Test = ( function()
{
    var message = "Hello World!";

    return {
        // Works well
        printTest: function() { window.alert(message); }
    };
}());
Run Code Online (Sandbox Code Playgroud)

请注意'return'语句后的花括号.

这是一个典型的愚蠢的菜鸟错误,并在某处有详细记录吗?

萤火虫无法给出一丝暗示.IE9和Chrome确实在代码的后面位置报告了一些模糊的语法错误:' function'statement in" printTest: function()" 之后的左括号.

对此有何评论?JavaScript中有更多这样的陷阱吗?

javascript

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