Object.assign() 函数与...state函数

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);

结果


image.png
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);

结果


image.png

由此可以看出,如果不需要改变目标函数,第一个参数就置为空对象

2、...state函数
测试01:

      let result01 = {type: '01', name: 'ming', age: 23};
        console.log(result01);
        console.log({...result01});
        console.log({result01});
        console.log([{...result01}]);

打印结果


image.png

说明 ...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});

打印结果


image.png

测试03:

      var arr0 = [0,1,2];
        var arr1 = [3,4];
        var arr3 = [arr0];
        var arr4 = [...arr0];
        console.log(arr3);
        console.log(arr4);

打印结果


image.png
      var arr0 = [0,1,2];
        var arr1 = [3,4];
        var arr3 = [arr0];
        var arr4 = [...arr0,{...arr1}];
        console.log(arr4);  

打印结果


image.png
       var arr0 = [0,1,2];
       var arr1 = [3,4,0];
       var arr3 = [arr0];
       var arr4 = [...arr0,...arr1];
       console.log(arr4);

打印结果


image.png

说明这是一个数据深拷贝的过程
把源对象的元素加入到目标函数中
对象合并

这样看...state与Object.assign()之间既有相似之处,也有各种特点
对比代码与结果,不难理解

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 属性的简洁表示法 ES6允许直接写入变量和函数,作为对象的属性和方法。这样的书写更加简洁。 上面代码表明,ES6允...
    呼呼哥阅读 7,995评论 0 2
  • 1 基本用法 Object.assign方法用于对象的合并,将源对象( source )的所有可枚举属性,复制到目...
    Api调用师阅读 4,340评论 0 4
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 13,910评论 1 32
  • 楔子:某日的一个下午一场考试结束,他和她再次相遇了。不知从什么时候起,他开始注意她,不知从什么时间起开始喜欢上她。...
    素心君阅读 4,589评论 0 1
  • 滴答……滴答……滴答…… 年轻的匠人一脸焦急的在钟楼的广场上来来回回的走着,视野在地面、砖缝、草丛里一点一点的搜寻...
    黄昏月影阅读 3,025评论 0 3

友情链接更多精彩内容