使用RXJS修补对象

时间:2016-10-09 20:09:42

标签: angular rxjs ngrx

我相信我想要实现的是类似于HTTP补丁或深度扩展功能,但我想用rxjs实现它。说我有以下对象:

const arr1 = {
  obj1: { a: 'dog', b: 'cat', c: 'bird' },
  obj2: { a: 'boy', b: 'girl', c: 'guitar' },
  obj3: { a: '1', b: '2', c: '3' }
}

const arr2 = {
  obj1: { a: 'wolf', b: 'lion', c: 'hawk', z: 'bear' },
  obj2: { c: 'car'}
}

然后我想使用rxjs来获得以下输出:

const output = {
  obj1: { a: 'wolf', b: 'lion', c: 'hawk', z: 'bear' },
  obj2: { a: 'boy', b: 'girl', c: 'car' },
  obj3: { a: '1', b: '2', c: '3' }
}

有没有一种有效的方法来实现这一目标?

1 个答案:

答案 0 :(得分:1)

RxJS不是用于合并对象,而是An API for asynchronous programming with observable streams

如果要合并对象,可以使用Lodash merge

var object = {
  'a': [{ 'b': 2 }, { 'd': 4 }]
};

var other = {
  'a': [{ 'c': 3 }, { 'e': 5 }]
};

_.merge(object, other);
// => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }

或对象传播运算符(未正式支持) https://babeljs.io/docs/plugins/transform-object-rest-spread/