object destructuring without var

前端 未结 3 1766
自闭症患者
自闭症患者 2020-11-22 07:30

Why does object destructuring throw an error if there is no var keyword in front of it?

{a, b} = {a: 1, b: 2};

throws Sy

3条回答
  •  难免孤独
    2020-11-22 08:01

    The issue stems from the {...} operators having multiple meanings in JavaScript.

    When { appears at the start of a Statement, it'll always represent a block, which can't be assigned to. If it appears later in the Statement as an Expression, then it'll represent an Object.

    The var helps make this distinction, since it can't be followed by a Statement, as will grouping parenthesis:

    ( {a, b} = objectReturningFunction() );
    

    From their docs: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Destructuring_assignment#Assignment_without_declaration

    Notes: The parentheses ( ... ) around the assignment statement are required when using object literal destructuring assignment without a declaration.

    {a, b} = {a: 1, b: 2} is not valid stand-alone syntax, as the {a, b} on the left-hand side is considered a block and not an object literal.

    However, ({a, b} = {a: 1, b: 2}) is valid, as is var {a, b} = {a: 1, b: 2}

    Your ( ... ) expression needs to be preceded by a semicolon or it may be used to execute a function on the previous line.

提交回复
热议问题