2

使用 jQuery - 我想比较 2 个 JSON 数组:

origArray来自数据库/C# API:

var origArray = [   {
        "TypeName": "Single",
        "TypeID": "3121",
        "TypeCount": "2"
        },
    {
        "TypeName": "Double",
        "TypeID": "4056",
        "TypeCount": "2"
        },
    {
        "TypeName": "Family",
        "TypeID": "5654",
        "TypeCount": "4"
        }
];

userArray是从用户输入中收集的:

var userArray = [   {
        "TypeID": "3121",
        "TypeCount": "2"
        },
    {
        "TypeID": "4056",
        "TypeCount": "3"
        },
    {
        "TypeID": "3121",
        "TypeCount": "3"
        }
];

我想做的是循环遍历userArray和TypeID的“组” ,并对TypeCount 求和

所以在上面的例子中:

TypeID: 3121
TypeCount: 5 (ie. 2 + 3)

TypeID: 4056
TypeCount: 3

这意味着 TypeID 3121 和 4056 之间会有 3 倍的差异。

有什么方法可以从 jQuery 或本机 Javascript 中获取这些信息(可以跨浏览器工作)?

谢谢你的帮助,

标记

4

5 回答 5

1

定义一个函数以按每个数组TypeID和 sum分组TypeCount

function groupByTypeID (arr) {
    var groupBy = {};
    $.each(arr, function () { 
      var currentCount = groupBy[this.TypeID] || 0; 
      groupBy[this.TypeID] = currentCount + parseInt(this.TypeCount);
    });
    return groupBy;
}

然后,对两个数组进行分组,并获取它们的差异:

var userArrayGroups = groupByTypeID(userArray);
var origArrayGroups = groupByTypeID(origArray);

var diff = {};
for (var prop in userArrayGroups) {
  diff[prop] = userArrayGroups[prop] - origArrayGroups[prop];
}

diff然后将持有以下内容:

{
  3121: 3
  4056: 1
}

演示

于 2012-08-28T14:14:42.097 回答
1

如果你熟悉 C# 这个 js 库 - linqjs。它包含所有 .NET 4.0 LINQ 方法和许多额外方法的实现。

于 2012-08-28T14:15:12.640 回答
1

你可以用下划线做到这一点:

var result = _.chain(userArray)
    .groupBy(function(value) {
      // group by the TypeId
      return value.TypeID;
    })
    .map(function(value) {
      // iterate over every group
      var addition = _.chain(value)
        .pluck("TypeCount") // create an array with TypeCount values
        .reduce(function(memo, num) {
          return Number(memo) + Number(num); // add all the TypeCount values
        })
        .value();

      return {
        "TypeID": value[0].TypeID, // TypeID
        "TypeCount": addition // total addition for this TypeID
      };
    })
    .value();

这里的工作示例:http: //livecoding.io/3498441

于 2012-08-28T14:23:17.777 回答
1

我会试一试...

var mergeArray = []
var index;

for (var i = userArray.length - 1; i >= 0; i--) {
    index = findByTypeID(mergeArray, userArray[i].TypeID);
    if(!index){
        mergeArray[index].TypeCount += parseInt(userArray[i].TypeCount)
    } else{
        mergeArray.push({
            "TypeID": userArray[i].TypeID,
            "TypeCount": parseInt(userArray[i].TypeCount)
        });
   }
};

function findByTypeID(arr, id){
    for (var i = arr.length - 1; i >= 0; i--) {  
        if(arr[i].TypeID == id)
             return i;
    };
    return -1;
}

这为您提供了您想要的数据结构输出mergeArray

于 2012-08-28T14:54:04.247 回答
-1
result = {};
for (var i in userArray) {
    var elem = userArray[i]
    if (!result[elem.TypeID])
      result[elem.TypeID] = elem.TypeCount;
    else
      result[elem.TypeID] += elem.TypeCount;
}

return result;
于 2012-08-28T14:18:09.620 回答