本篇没有的请翻看【对象的扩展】系列的其他篇
本节内容属于es7特性,chrome默认不支持es7。
如果想要使用这些特性,阅读该链接
简单粗暴的说,就是指在解构赋值时,让所有未被辅助的对象,被解构赋值到某个属性上。
示例代码:
var {x, ...y} = {x: 1, a: 2, b: 3};
x; //1
y; //{a: 2, b: 3}
x有对应的,所以被赋值为1。剩下的a和b没有对应的,但是左边的y有扩展运算符...
,所以a与b全部以kv的形式,被添加到对象中并赋值给y
注意:
1、不能复制set和get属性;
let foo = {
_val: 0,
get val() {
return this._val + 1;
},
set val(val) {
this._val = val;
}
}
let {...y} = foo;
y; //{_val: 0, val: 1}
foo.val = 1; //
foo.val; //2
y.val = 1;
y.val; //1
2、属性的enumerable为false的,会被忽视。
let foo = Object.defineProperties({}, {
val: {
value: 1,
enumerable: true
},
cannot: {
value: 2
}
});
let {...y} = foo;
y; //{val: 1}
3、原型链上的属性,也会被忽视
function Child() {
this.a = "a";
}
function Father() {
this.b = "b";
}
Child.prototype = new Father();
let foo = new Child();
let {...y} = foo;
y; //{val: 1}
4、只能解构赋值时,只能有一个属性使用该运算符,如果大于一个则会报错;
let foo = {a: 1, b: 2, c: 3}
let {...x, ...y} = foo; //Uncaught SyntaxError: Rest element must be last element
{…obj}
效果:
console.log(...[a:1])
,但不能console.log(...{a:1})
与对数组使用扩展运算符的对比:
我们之前提过,当扩展运算符…在等式右边的时候,会遍历数组所有元素。如代码:
let a = [1, 2, 3];
let b = [...a, 4];
b; //[1, 2, 3, 4]
在对数组使用的时候,可以方便的将数组元素合并起来。
同样,对对象也可以这么使用。例如代码:
let a = {
a: 1,
b: 2
}
let b = {...a, c: 3};
b; //{a: 1, b: 2, c: 3}
有点像
let b = Object.assign({}, a, {c: 3});
只不过本方法不会对a和b造成影响,但注意,这种方法对按引用传递类型是浅复制的。
对象的合并
除了上面那种类似数组的写法外,也可以用来合并2个对象(或者数组):
let foo = {a: 1};
let bar = {b: 2};
let test = {...foo, ...bar}; //与之前的写法区别在于c:3和...{c:3}
test; //{a: 1, b: 2}
//数组版
let foo = [1, 2]
let bar = [3, 4]
let test = [...foo, ...bar];
test; //[1,2,3,4]
将上面抽象出来:
let foo = {...{a: 1}, ...{b: 2}};
foo; //{a: 1, b: 2}
提示:
chrome版本 58.0.3029.110,打开js新特性开关,依然不能使用。
所以略