我有两个对象:oldObj
和newObj
。
输入的数据oldObj
用于填充表单,newObj
是用户更改此表单中的数据并提交的结果。
两个物体都很深,即。它们具有对象或对象数组等属性 - 它们可以是 n 级深,因此 diff 算法需要递归。
现在我需要不只是从弄清楚什么改变(如添加/更新/删除)oldObj
来newObj
,却怎么也最能代表它。
到目前为止,我的想法只是构建一个genericDeepDiffBetweenObjects
方法来返回表单上的对象,{add:{...},upd:{...},del:{...}}
但后来我想:之前一定有人需要这个。
那么......有没有人知道一个库或一段代码可以做到这一点,并且可能有更好的方式来表示差异(以仍然是 JSON 可序列化的方式)?
更新:
我想到了一种更好的方法来表示更新的数据,使用与 相同的对象结构newObj
,但将所有属性值转换为表单上的对象:
{type: '<update|create|delete>', data: <propertyValue>}
所以,如果newObj.prop1 = 'new value'
和oldObj.prop1 = 'old value'
它会设置returnObj.prop1 = {type: 'update', data: 'new value'}
更新 2:
当我们处理作为数组的属性时,它真的很麻烦,因为数组[1,2,3]
应该被计算为等于[2,3,1]
,这对于基于值的类型(如 string、int 和 bool)的数组来说足够简单,但是当涉及到时就变得非常难以处理引用类型的数组,如对象和数组。
应该被发现相等的示例数组:
[1,[{c: 1},2,3],{a:'hey'}] and [{a:'hey'},1,[3,{c: 1},2]]
检查这种类型的深层值相等性不仅非常复杂,而且要找出一种表示可能发生的变化的好方法。