javascript - L'un est un tableau et l'autre un objet. Comment comparer et supprimer les doublons?
仅有的幸福
仅有的幸福 2017-07-05 10:53:25
0
4
870
var arr=[{'id':1,'name':1},{'id':2,name:2},{'id':3,'name':3}];
var obj = {'id':2,'name':2};

Comment comparer arr et obj ? Après avoir constaté que id2 est répété, supprimez l'objet tableau id:2 de arr et générez un nouveau tableau ?

仅有的幸福
仅有的幸福

répondre à tous(4)
给我你的怀抱

Utilisez le filtre de tableau pour filtrer afin de générer un nouveau tableau.
De plus, la deuxième partie du tableau dans la question 'id:2'contient une erreur grammaticale et les guillemets sont au mauvais endroit

var res = arr.filter(function(e){
    return e.id!=obj.id
})

Ce qui suit est mon imagination : et si le point clé de la question était que les paires clé-valeur soient répétées avant le filtrage... (je réfléchis peut-être trop)

Considérant que vous souhaiterez peut-être également vous assurer que les paires clé-valeur des éléments du tableau doivent être exactement les mêmes que les paires clé-valeur de l'obj : vous pouvez considérer ceci

var arr=[{'id':1,'name':1},{id:2,name:3},{'id':3,'name':3}];
var arr2=[{'id':1,'name':1},{id:2,name:2},{'id':3,'name':3}];
var obj = {'id':2,'name':2};
var res = arr.filter(function(e){//
  var result = true; //作为过滤标识
  for(var key in obj){//遍历obj的键值
      if(e[key]!=obj[key]){//如果出现键值相同当值不同,就不算重复
           result = true;
          break;
      }
      //如果上面条件不通过,那就表示键值重复
      result = false;
   }//遍历到最后,如果键值都重复,那result肯定是false,否则必然出现result=true的情况
   return result;
});
var res2 = arr.filter(function(e){
  var result = true; 
  for(var key in obj){
      if(e[key]!=obj[key]){
           result = true;
          break;
      }
      result = false;
   }
   return result;
});
洪涛
var newArr = arr.filter(item => item.id !== obj.id)
迷茫
var arr=[{'id':1,'name':1},{'id':2,name:2},{'id':3,'name':3}];
var obj = {'id':2,'name':2};

var index = -1;
for (let i = 0; i < arr.length; i++) {
    let flag = false;
    for (let item in obj) {
        if (obj[item] !== arr[i][item]) {
            flag = true;
        }
    }
    if (!flag) {
        index = i;
    }
}
console.log(index);
arr.splice(index,index>0);
console.log(arr);
为情所困

Array.prototype.filter()

var arr=[{'id':1,'name':1},{'id':2,name:2},{'id':3,'name':3}];
var obj = {'id':2,'name':2};
var newArray = arr.filter((obj_)=>(obj_.id !== obj.id))
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal