解构赋值-《understanding ECMAScipt6》读
2017-04-26 本文已影响20人
aliyu
对象解构赋值
let node = {
type: "string",
name: "foo"
};
let {type, name} = node;
需要注意的点:
- 当等式右边是
null
或者undefined
会报错 - 如果等式左边有的值在等式右边找不到,则该值为
undefined
- 可以给左边设定默认值,且默认值只有当预期值
===undefined
才能够生效 - 可以不使用默认名称,例
let {type:newType, name: newName} = node
- 上面两个可以组合使用
- 可以使用嵌套子对象的结构赋值
let node = { name: "foo", othenInfo: { height: 188 } }; let {otherInfo:{height}, name} = node;
- 解构的值只会赋值到key/value中的value
数组解构赋值
- 可以交换对象,例:
let [a,b] = [b, a]
- 可以设定默认值
- 可以解构嵌套数组
- 可以使用rest写法,同函数中提到的一样,rest写法只能放在数组的最后一项
混合解构
可以将数组和对象混合体放在一起解构,然而并没有什么好说的。
常用方法
在函数设定默认参数时,例如
setCookie(name, value, {secure, path, domain, expires} = {}){
//dosomething
}
//给后面参数解构赋值为空对象时,就算传参进来的是undefined也不会报错