JavaScript中的逗号运算符:应为语法错误,但代码运行正常

Comma operator in JavaScript: syntax error expected, but code runs OK

本文关键字:错误 代码 运行 语法 运算符 JavaScript      更新时间:2023-09-26

我刚刚修复了我的一个微不足道的web应用程序中的一些错误,并偶然发现了一些有趣的行。我不记得我为什么要按照原来的方式执行这些线路。现在我把它们改成了"普通"语法,一切都很好。我的问题只是出于好奇:为什么这个方法有效?我预计会出现语法错误,但事实并非如此。代码确实有效。

这是旧方法的实现:

ListFillFilter: function(list){
    if (OC.Shorty.Debug) OC.Shorty.Debug.log("using 'default' method to filter filled list");
    // only makes sense for default OC.Shorty list
    var data=new Array();
    data['sum_shortys']=$('#desktop #list-of-shortys tbody tr').length;
    data['sum_clicks']=0;
    $('#desktop #list-of-shortys tbody tr').each(function(){
        data['sum_clicks']+=parseInt($(this).attr('data-clicks'),10);
    });
    OC.Shorty.WUI.Sums.fill.apply(OC.Shorty.Runtime.Context.ListOfShortys,[data]),
    // filter list
    OC.Shorty.WUI.List.filter.apply(this,[list,'target',list.find('thead tr#toolbar th#target #filter').val()]),
    OC.Shorty.WUI.List.filter.apply(this,[list,'title', list.find('thead tr#toolbar th#title #filter').val()]),
    OC.Shorty.WUI.List.filter.apply(this,[list,'status',list.find('thead tr#toolbar th#status select :selected').val()])
    // sort list
    $.when(
        OC.Shorty.Action.Preference.get('list-sort-code')
    ).done(function(pref){
        OC.Shorty.WUI.List.sort(list,pref['list-sort-code']);
    })
}, // OC.Shorty.Runtime.Context.ListOfShortys.ListAddInsert

在中间,您可以看到5行都以"OC.Shorty.WUI.Sums.fill.apply"开头。这些行以逗号(",")而不是分号(";")结尾。为什么没有显示为语法错误?

基本上,逗号运算符将多个表达式分组在一起,它们表示最后一个表达式的值。在你的情况下,你也可以省略它

想象一下你有这样的代码:

1
2
3

这是非常有效的JavaScript代码。这些数字只是用来表示三个任意的表达式。

如果您要执行以下操作:

var expression_value = 1
2
3

CCD_ 1将具有值CCD_。

如果使用逗号运算符和括号:

expression_value = (1,
2,
3)

它将具有值3,因为逗号运算符返回最右边表达式的值。

如果不使用任何括号,则以下括号将是隐含

implied = ((expression_value = 1),
2,
3)

expression_value将具有值1,但implied(即整个表达式)现在将具有值3。

逗号运算符标记序列;JS插入额外的";"s仅在行末尾(如果这是使代码可解析所必需的)。因此,像这样的代码

alert("hi"),
alert("there"),
alert("bob") // no semi-colon here

是完全有效的-它被理解为

alert("hi"),
alert("there"),
alert("bob"); // notice the semi-colon

而不是(非法的)

alert("hi"),;
alert("there"),;
alert("bob");

不过,依赖分号的自动插入被认为是不好的风格。

此语法使用逗号运算符,。它计算所有操作数,并返回最后一个操作数的值。

使用这种编码风格的原因是为了快速或在一行中执行代码。这里有一个例子:

var a = 0,
    b = 1,
    c;
c = ( a++, b++, a + 2 ); // a is incremented, b is incremented, then c is assigned a + 2
a; // 1
b; // 2
c; // 3