js实现两个对象的深度合并

es6新增的Object.assign()方法只会合并替换对象的第一层key,对于多层的,会当做值处理。

let obj1 = {
  a: {
    b: {
      c: "111"
    }
  }
};

let obj2 = {
  a: {
    b: {
      d: "222"
    }
  }
};

const obj = Object.assign(obj1, obj2);

console.log(obj);

//  console.log的结果如下:

//  {"a":{"b":{"d":"222"}}}

 

以下方法实现对象多层的深度合并

let obj1 = {
  a: {
    b: {
      c: "111"
    }
  }
};

let obj2 = {
  a: {
    b: 'ABC'
  }
}

方法一

function deepMerge(obj1, obj2) {
  let key;
  for (key in obj2) {
    // 如果target(也就是obj1[key])存在,且是对象的话再去调用deepMerge,否则就是obj1[key]里面没这个对象,需要与obj2[key]合并
    obj1[key] = obj1[key] && obj1[key].toString() === "[object Object]" ? deepMerge(obj1[key], obj2[key]) : (obj1[key] = obj2[key]);
  }
  return obj1;
//  obj1  的结果如下:

//  {"a":{"b":{"0": "A", "1": "B", "2": "C", "c": "111"}}}
}



或者使用下面的方法

方法二

function deepMerge(obj1, obj2) {
  let key;
  for (key in obj2) {
    // 如果target(也就是obj1[key])存在,且是对象的话再去调用deepMerge,否则就是obj1[key]里面没这个对象,需要与obj2[key]合并
    // 如果obj2[key]没有值或者值不是对象,此时直接替换obj1[key]
    obj1[key] = obj1[key] && obj1[key].toString() === "[object Object]" && (obj2[key] && obj2[key].toString() === "[object Object]") ? deepMerge(obj1[key], obj2[key]) : (obj1[key] = obj2[key]);
  }
  return obj1;
//  obj1  的结果如下:

//  {"a":{"b":"ABC"}}
}

 

JavaScript中,可以使用递归实现两个JSON对象深度合并和替换。具体步骤如下: 1. 遍历第一个JSON对象的所有属性,如果属性在第二个JSON对象中不存在,则将该属性添加到第二个JSON对象中。 2. 如果属性在第二个JSON对象中也存在,则需要进行合并或替换操作: a. 如果属性是基本数据类型,直接替换第二个JSON对象中对应属性的值; b. 如果属性是数组类型,则将第二个JSON对象中对应属性的数组与第一个JSON对象中对应属性的数组进行合并或替换操作,合并或替换后的数组替换第二个JSON对象中对应属性的值; c. 如果属性是对象类型,则需要递归调用深度合并函数,将第一个JSON对象中对应属性的值与第二个JSON对象中对应属性的值进行合并或替换操作,合并或替换后的对象替换第二个JSON对象中对应属性的值。 3. 最后返回合并或替换后的第二个JSON对象。 以下是一个示例代码,实现两个JSON对象深度合并和替换: ```javascript function mergeJSON(json1, json2) { for (let key in json1) { if (json1.hasOwnProperty(key)) { if (json2.hasOwnProperty(key)) { if (typeof json1[key] === 'object' && typeof json2[key] === 'object') { json2[key] = mergeJSON(json1[key], json2[key]); } else { json2[key] = json1[key]; } } else { json2[key] = json1[key]; } } } return json2; } ``` 可以通过以下方式调用该函数: ```javascript let json1 = {"name": "John", "age": 30, "hobbies": ["reading", "swimming"], "address": {"city": "Beijing", "country": "China"}}; let json2 = {"name": "Peter", "age": 25, "hobbies": ["singing", "dancing"], "address": {"city": "Shanghai"}}; let mergedJSON = mergeJSON(json1, json2); console.log(JSON.stringify(mergedJSON, null, 2)); ``` 输出结果如下: ```json { "name": "Peter", "age": 25, "hobbies": [ "singing", "dancing", "reading", "swimming" ], "address": { "city": "Shanghai", "country": "China" } } ``` 在上面的示例中,我们对第二个JSON对象进行了深度合并和替换操作,将第一个JSON对象的属性合并或替换到第二个JSON对象中,最终得到了合并或替换后的第二个JSON对象
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值