1、Object.assign()函数
Object.assign(target, source)
target为目标对象
source为源对象
该函数的作用是以目标对象为基础,将源对象中的内容更新到目标对象中,有则替换,无则新增
var result01 = {type: '01', name: 'ming', age: 23};
let result02 = {type: '02', marry: false};
let result03 = {type: '03', age: 55}
const result = Object.assign({}, result01, result02, result03);
DLog(result,result.name,result.type,result01);
结果
data:image/s3,"s3://crabby-images/9dd43/9dd43a6852d959955eb26f9831fd559fb8d6d203" alt=""
var result01 = {type: '01', name: 'ming', age: 23};
let result02 = {type: '02', marry: false};
let result03 = {type: '03', age: 55}
const result = Object.assign(result01, result02, result03);
DLog(result,result.name,result.type,result01);
结果
data:image/s3,"s3://crabby-images/b1fcb/b1fcb54542ed3da98efb052ca79c2abda4c1243c" alt=""
由此可以看出,如果不需要改变目标函数,第一个参数就置为空对象
2、...state函数
测试01:
let result01 = {type: '01', name: 'ming', age: 23};
console.log(result01);
console.log({...result01});
console.log({result01});
console.log([{...result01}]);
打印结果
data:image/s3,"s3://crabby-images/67757/67757066bbbfb8c1b5dea133aed0f03f1fe2fe3b" alt=""
说明 ...state 是把对象的元素拿出来作为一个新的集合
测试02:
let result01 = {type: '01', name: 'ming', age: 23};
let result02 = {type: '02', marry: false};
let result03 = {type: '03', age: 55,address:'beijing'}
const result = Object.assign({},result01, result02, result03);
console.log({...result02,...result03});
打印结果
data:image/s3,"s3://crabby-images/ab804/ab80400842f1441b8bc1b1b3e58322f04909aafc" alt=""
测试03:
var arr0 = [0,1,2];
var arr1 = [3,4];
var arr3 = [arr0];
var arr4 = [...arr0];
console.log(arr3);
console.log(arr4);
打印结果
data:image/s3,"s3://crabby-images/c7566/c75664555a6d4c7a76bd3c723cd412a9c4b558fc" alt=""
var arr0 = [0,1,2];
var arr1 = [3,4];
var arr3 = [arr0];
var arr4 = [...arr0,{...arr1}];
console.log(arr4);
打印结果
data:image/s3,"s3://crabby-images/e76f7/e76f762435a73688faa527e40080ad98c3a138d3" alt=""
var arr0 = [0,1,2];
var arr1 = [3,4,0];
var arr3 = [arr0];
var arr4 = [...arr0,...arr1];
console.log(arr4);
打印结果
data:image/s3,"s3://crabby-images/7554e/7554e66b3fd5353e03e395d210f0daaaeb18a174" alt=""
说明这是一个数据深拷贝的过程
把源对象的元素加入到目标函数中
对象合并
这样看...state与Object.assign()之间既有相似之处,也有各种特点
对比代码与结果,不难理解
网友评论