合并对象的常见方法

150 篇文章 2 订阅
36 篇文章 0 订阅

可以使用 Object.assign()或扩展运算符 ... 来合并 js 对象。

下面是两种合并对象的方式:

一、常见方法 

1、Object.assign()

    let obj1 = { a: 1, b: 2 };
    let obj2 = { c: 3, d: 4, e: {name: '我是小草莓'} };
    const mergedObj = Object.assign({}, obj1, obj2);
    console.log(mergedObj); // { a: 1, b: 2, c: 3, d: 4, e: {name: "我是小草莓"} }

    obj1.a = 1111
    console.log(mergedObj); // { a: 1, b: 2, c: 3, d: 4, e: {name: "我是小草莓"} }

    // 浅拷贝
    obj2.e.name = '我是改过的小草莓'
    console.log(mergedObj); // { a: 1, b: 2, c: 3, d: 4, e: {name: "我是改过的小草莓"} }

2、扩展运算符 ... 

    let obj1 = { a: 1, b: 2 };
    let obj2 = { c: 3, d: 4, e: {name: '我是小草莓'} };
    const mergedObj = {...obj1, ...obj2};
    console.log(mergedObj); // { a: 1, b: 2, c: 3, d: 4, e: {name: "我是小草莓"} }

    obj1.a = 1111
    console.log(mergedObj); // { a: 1, b: 2, c: 3, d: 4, e: {name: "我是小草莓"} }

// 浅拷贝
    obj2.e.name = '我是改过的小草莓'
    console.log(mergedObj); // { a: 1, b: 2, c: 3, d: 4, e: {name: "我是改过的小草莓"} }

二、使用注意 

注意的是,

① 如果合并的对象中有同名属性,则后面的属性值会覆盖前面的属性值。

② 以上2种方式合并对象,属于浅拷贝的方式。只有第一层是深拷贝,第二层及以上都是浅拷贝

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值