使用Javascript/JQuery在JSON对象中的差异

Al.*_*Al. 16 javascript jquery json

我在Javascript中有两个JSON对象,除了数值之外都是相同的.它看起来像这样:

var data = {
  "eth0":{"Tx":"4136675","Rx":"13232319"},
  "eth1":{"Tx":"4","Rx":"0"},
  "lo":{"Tx":"471290","Rx":"471290"}
}

var old = {
  "eth0":{"Tx":"4136575","Rx":"13232219"},
  "eth1":{"Tx":"4","Rx":"0"},
  "lo":{"Tx":"471290","Rx":"471290"}
}
Run Code Online (Sandbox Code Playgroud)

一个名为"data"的对象具有当前值,另一个名为"old"的对象具有1秒前的相同值.我想输出一个只有值更改的JSON对象,这样我就可以计算网络接口上的数据吞吐量.

var throughput = {
  "eth0":{"Tx":"100","Rx":"100"},
  "eth1":{"Tx":"0","Rx":"0"},
  "lo":{"Tx":"0","Rx":"0"}
}
Run Code Online (Sandbox Code Playgroud)

我不确定如何遍历JSON数据 - 它可以用于任何数量的接口.

有人可以借给我一个手吗?提前致谢

Pet*_*ley 14

在JavaScript中迭代对象的基本前提是这样的

var whatever = {}; // object to iterate over
for ( var i in whatever )
{
  if ( whatever.hasOwnProperty( i ) )
  {
     // i is the property/key name
     // whatever[i] is the value at that property
  }
}
Run Code Online (Sandbox Code Playgroud)

修理检查器不会太难.你需要递归.我会把它留作你或其他SOer的练习.


Ben*_*nja 8

也许它已经回答得足够了,但是让我添加我的无耻插件:)一个JSON(实际上是任何javascript对象或数组结构)差异和补丁库我在github上开源:

https://github.com/benjamine/jsondiffpatch

它生成差异(也是JSON格式,占用空间小),您可以使用客户端(检查测试页面)和服务器端,如果存在,则使用http://code.google.com/p/google -diff-match-patch /自动长字符串.

检查DEMO页面以查看其工作原理.


CMS*_*CMS 7

您可以遍历父对象和子对象属性:

var diff = {};
for(var p in data){
  if (old.hasOwnProperty(p) && typeof(data[p]) == 'object'){
    diff[p] = {};
    for(var i in data[p]){
      if (old[p].hasOwnProperty(i)){
        diff[p][i] = data[p][i] - old[p][i];
      }
    }
  }
}
Run Code Online (Sandbox Code Playgroud)


asb*_*nge 5

当我处理类似的问题时,这对我起了作用。与第一相比,它在第二中得到了差异。

var first  = originalObj;
var second = modifiedObj;
var diff   = {};

var differ = function(first, second, result) {
    var i = 0;
    for (i in first) {
        if (typeof first[i] == "object" && typeof second[i] == "object") {
            result[i] = differ(first[i], second[i], {});
            if (!result[i]) delete result[i];
        } else if (first[i] != second[i]) {
            result[i] = second[i];
        }
    }
    return isEmpty(result) ? undefined : result;
}

differ(old_conf, new_conf, diff);
Run Code Online (Sandbox Code Playgroud)

代码有点特殊,但您可以了解总体思路:P