扩展两个没有深层复制但没有覆盖对象数组的对象

时间:2017-09-25 15:03:25

标签: javascript jquery

我有两个对象,我想通过覆盖相同的值来加入一个。

var objOne = { current: 1, sort: { 'foo' : 'bar' }, search: [ { name: 'a', value: 1 }, { name: 'b', value: 2 } ] };
var objTwo = { sort: { 'john' : 'doe' }, search: [ { name: 'a', value: 3 } ] };

我尝试使用$ .extends而没有深层复制,并且适用于除数组对象之外的所有元素。

var objAll = $.extend( {}, objOne, objTwo );

objAll -> { current: 1, sort: { 'john' : 'doe' }, search: [{ name: 'a', value: 3 }] };

我的目标是获得这个

objAll -> { current: 1, sort: { 'john' : 'doe' }, search: [{ name: 'a', value: 3 },{ name: 'b', value: 2 }] };

仅覆盖具有相同名称的对象数组。

我该怎么做?感谢

1 个答案:

答案 0 :(得分:0)

这可以使用ES6代理完成,在处理程序中使用set trap。

var objOne = {    current: 1,    sort: { 'foo' : 'bar' },    search: [ { name: 'a', value: 1 }, { name: 'b', value: 2 } ]  };

var proxy = new Proxy(objOne, {
         set(trapTarget, key, value, receiver) {
              // not altering the existing array properties
              if (trapTarget.hasOwnProperty(key) && Array.isArray(trapTarget[key])) {

                return Reflect.set(trapTarget, key, trapTarget[key], receiver)  
              } 

              return Reflect.set(trapTarget, key, value, receiver);

         } });

Object.assign(proxy,{ sort: { 'john' : 'doe' }, search: [ { name: 'a', value: 3 } ] });

console.log(objOne); 

JsFiddle链接:https://jsfiddle.net/8n3c8hs0/