javascript - 使用下划线替换或推送数组中的对象

标签 javascript arrays underscore.js

我有一个包含新数据的对象和一个包含已保存数据的数组。如果来自 newData 的 cnName 已经存在于 cnData 数组的 savedData 中,那么 savedData 中的那个对象应该被替换为 newData.cnData[0] 对象。如果不存在则将数据推送到 savedData 中的 cnData 数组

newData = {
  "cnGroupName": "cnGroupName1",
  "cnData": [{
    "cnName": "cn3",
    "data": {
       "color": "blue",
       "size": "42",
       "position": "right"
    }
  }]
}

savedData = [{
  "cnGroupName": "cnGroupName1",
  "cnData": [{
    "cnName": "cn1",
    "data": {
      "color": "red",
      "size": "42",
      "position": "right"
    }
  }, {
    "cnName": "cn2",
    "data": {
      "color": "blue",
      "size": "11",
      "position": "top"
    }
  }]
}]

我正在使用下划线

if(savedData.length){
    _.each(savedData, function(num, i){

        if(savedData[i].cnGroupName == newData.cnGroupName ){

            _.each(savedData[i].cnData, function(num, x){


               if(savedData[i].cnData[x].cnName == newData.cnData[0].cnName){

                    // the cnName already exists in savedData so replace
                    savedData[i].cnData[x] = newData.cnData[0] 


               }else{ 
                    // the cnName  does NOT exist in savedData so push the new object to savedData
                   savedData[i].cnData.push(newData.cnData[0])
                }
            })
        }else{
            // the cnGroupName from newData is not in saveData so push newData
            savedData.push(newData)
        }
    })
}

这不起作用的原因是因为在第二个 _.each() 语句中。如果 cnName 在 savedData 中不存在,它将为已在 savedData 中的每个对象推送一次 newData。因此,如果 savedData 中已经有 2 个保存的对象,那么 newData 将被推送 2 次

你可以在这个 plunker 中看到控制台日志,新数据被推送了两次

http://plnkr.co/edit/GkBoe0F65BCEYiFuig57?p=preview

我的两个问题是

  1. 在下划线中有更简洁的方法吗?
  2. 有没有办法阻止 _.each() 继续循环?

最佳答案

您可以使用 findIndex 找到第一个匹配的索引,如果找不到则更新。

if(savedData.length){
    var cnindex,
    index = _.findIndex(savedData, function (item) { return item.cnGroupName == newData.cnGroupName });
    if (index === -1)) {
        savedData.push(newData);
    } else {
        cnindex = _.findIndex(savedData[index].cnData, function (item) {return item.cnName == newData.cnData[0].cnName});
        if (cnindex === -1) {
            savedData[index].cnData.push(newData.cnData[0]);
        } else {
            savedData[index].cnData[cnindex] = newData.cnData[0];
        }
    }
}

注意:要在 try catch block 中停止每次迭代并在所需的断点处抛出自定义错误

关于javascript - 使用下划线替换或推送数组中的对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30311523/

相关文章:

javascript - 使用 JQuery 从列表中删除除前 N 个元素之外的所有元素

javascript - 被覆盖后检索/恢复 native javascript函数

java - 在字符串中添加字符

javascript - 在 LODASH 中,断言对象或数组中存在键的最佳方法是什么?

javascript - 在下划线模板中的对象上调用函数

javascript - 将字符串数组转换为日期,对其进行过滤并转换回字符串

javascript - 对象已排序,但未使用 lodash sortBy 保留其键

php - 通过 jQuery 检查属性 href

java - Java 数组中的删除

javascript - Backbone.js 未捕获下划线模板的引用错误