运算符优先级:!并等待

时间:2017-07-06 09:22:43

标签: javascript syntax safari async-await operator-precedence

在JavaScript中,如何解释以下语句:

cond1 && !await f()

这是

行的摘录
if(cond1 && !await f()){
    do_stuff();
}

在生产应用程序中。 chrome似乎很好用,但在ios上这会导致错误读取

unexpected identifier 'f'. Expected ')' to end an if condition.

看起来ios将!await f()变为(!await)(f())而不是!(await f())

现在我的问题:根据ECMA-262对上述行的正确解释是什么?

p.s。:我们已经修改了ios的代码,方法是将其更改为

var f_result = await f();
if(cond1 && !f_result){
    do_stuff();
}

1 个答案:

答案 0 :(得分:3)

这与运算符优先级无关。由于两者都是一元前缀运算符,因此只能通过单一方式解释此表达式 - 所有deletevoidtypeof+,{{ 1}},-~!使用相同的生产目标进行解析,并且可以任意嵌套。是的,它是ES2017中的有效语法。