一、对象解构
在此代码中, node.type 的值被存储到 type 本地变量中, node.name 的值则存储到name 变量中。此语法相同于简写的属性初始化器。 type 与 name 标识符既声明了本地变量,也读取了对象的相应属性值。
以上对象解构示例都用于变量声明。不过,也可以在赋值的时候使用解构。例如,你可能想
在变量声明之后改变它们的值,如下所示:
在本例中, type 与 name 属性在声明时被初始化,而两个同名变量也被声明并初始化为不同的值。接下来一行使用了解构表达式,通过读取 node 对象来更改这两个变量的值。注意你必须用圆括号包裹解构赋值语句,这是因为暴露的花括号会被解析为代码块语句,而块语句不允许在赋值操作符(即等号)左侧出现。圆括号标示了里面的花括号并不是块语句、而应该被解释为表达式,从而允许完成赋值操作。
二、解构赋值表达式的值为表达式右侧(在 = 之后)的值
outputInfo() 函数被使用一个解构赋值表达式进行了调用。该表达式计算结果为 node ,因为这就是表达式右侧的值。对 type 与 name 的赋值正常进行,同时 node 也被传入了outputInfo() 函数。
当解构赋值表达式的右侧( = 后面的表达式)的计算结果为 null 或 undefined 时,会抛出错误。因为任何读取 null 或 undefined 的企图都会导致“运行时”错误(runtime error )。
三、默认值
当你使用