最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Why does the logical or operator (||) with an empty arrow function (()=>{}) cause a SyntaxError? - Stack Ove

programmeradmin0浏览0评论

In my code, I have something that boils down to this:

var x = y || ()=>{};

(In case you are wondering, I am later calling x() and y may be defined as a function or it might not, so I don't want a TypeError to be thrown if it is not.)

For some reason, this causes a

SyntaxError: Unexpected token )

Why? I found out that

var x = y || (()=>{});

works just fine, but

y || ()=>{}

dosen't work. Is this specced, or a bug in V8 or Chrome? (I tested this only in the latest release of Chrome stable.)

In my code, I have something that boils down to this:

var x = y || ()=>{};

(In case you are wondering, I am later calling x() and y may be defined as a function or it might not, so I don't want a TypeError to be thrown if it is not.)

For some reason, this causes a

SyntaxError: Unexpected token )

Why? I found out that

var x = y || (()=>{});

works just fine, but

y || ()=>{}

dosen't work. Is this specced, or a bug in V8 or Chrome? (I tested this only in the latest release of Chrome stable.)

Share Improve this question asked Mar 8, 2017 at 18:25 user7586097user7586097 2
  • 1 This is described on MDN. It's just the order of parsing. – Scott Sauyet Commented Mar 8, 2017 at 18:32
  • 1 Interestingly, this works with a regular function. – user6560716 Commented Mar 8, 2017 at 19:06
Add a ment  | 

3 Answers 3

Reset to default 18

This is normal. Unlike a function expression, which is a PrimaryExpression like other literals and identifiers, and arrow function specifically is an AssignmentExpression and can only appear inside grouping, ma, assignment, conditional (ternary) and yield expressions. Any other operator than those would lead to ambiguities.

For example, if you expect y || ()=>z to work, then also ()=>z || y should be expected to work (assuming symmetric precedence). That however clearly collides with our expectation that we can use any operators inside concise bodies of arrow functions. Therefore, it's a syntax error and requires explicit grouping to work and stay maintainable.

This is not a bug in the JavaScript engine. This behavior is documented.

Although the arrow in an arrow function is not an operator, arrow functions have special parsing rules that interact differently with operator precedence pared to regular functions.

Source: https://developer.mozilla/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions#Parsing_order

try this var x =( y || (()=>{}));

与本文相关的文章

发布评论

评论列表(0)

  1. 暂无评论