JS运算符 (...)了解及使用

这个运算符一般用于数组数据获取 数据解构合并等

这个一般用于数组,对对象直接使用的话会报错

展开项

let a = [1,2,,4,4];
let b = [2,3,4];
console.log(a);      // [1, 2, empty, 4, 4]
console.log(...a);   // 1 2 undefined 4 4
console.log([...a, ...b]);   // [1, 2, undefined, 4, 4, 2, 3, 4]

解构

var d,e,rest;
[d,e,...rest] = [1,2,3,4,5,6,7,8,9];
console.log("d, e, rest", d, e, rest)   // d, e, rest 1 2 (7) [3, 4, 5, 6, 7, 8, 9]

注意这里的顺序问题:

 这么写是报错的

获取全部参数 

function sum(...num){
	console.log('num', num);  // num (4) [1, 2, 3, 4]
	return num.reduce((pre, cur) => {
		return pre + cur
	})
}
console.log(sum(1,2,3,4));   // 10

对象使用

注:对象使用的话必须在外层添加 {}  ,否则会报错

// 构造字面量对象使用展开语法
let person = { name: '小张', age: 12}
let person2 = {...person}

// console.log(...person);  // 报错  展开运算符不能使用在对象上
// 下面的写法 是创建对象字面量的形式
person.name = 'jerry';
console.log("person", person);    // person {name: 'jerry', age: 12}
console.log("person2", person2);  // person2 {name: '小张', age: 12}

可以看到对象的深拷贝是可以

对象合并

// 合并
let person = { name: '小张', age: 12}
let person3 = { ...person,name: 'jack',address:"12233"}
console.log("person3",person3);   // person3 {name: 'jack', age: 12, address: '12233'}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值