比较两个Javascript数组并删除重复项

sun*_*leo 36 javascript

如果它有另一个数组的元素,有没有其他更好的方法从一个数组中删除重复项?

<script>
var array1 = new Array("a","b","c","d","e","f");
var array2 = new Array("c","e");

for (var i = 0; i<array2.length; i++) {
    var arrlen = array1.length;
    for (var j = 0; j<arrlen; j++) {
        if (array2[i] == array1[j]) {
            array1 = array1.slice(0, j).concat(array1.slice(j+1, arrlen));
        }
    }
}
alert(array1);

</script>
Run Code Online (Sandbox Code Playgroud)

Aes*_*ete 110

array1 = array1.filter(function(val) {
  return array2.indexOf(val) == -1;
});
Run Code Online (Sandbox Code Playgroud)

或者,随着ES6的可用性:

array1 = array1.filter(val => !array2.includes(val));
Run Code Online (Sandbox Code Playgroud)

filter()在这里引用

indexOf()这里引用

包括()在这里引用

  • 作为上述代码的旁注和解释:“indexOf:返回等于指定值的数组中元素的第一个(最小)索引,如果没有找到,则返回 -1。” (https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array?redirectlocale=en-US&amp;redirectslug=JavaScript%2FReference%2FGlobal_Objects%2FArray) (2认同)
  • 我喜欢它,但它肯定需要解释,或者至少需要一个链接来引导某人到解释它的正确位置。 (2认同)
  • 很棒的一段代码,但请注意,如果您有嵌套数组,它就不起作用。 (2认同)

Ben*_*ers 8

出于我无法理解的原因,诀窍是将外循环向下 (i--) 和内循环向上 (j++)。

请参阅下面的示例:

function test() {
  var array1 = new Array("a","b","c","d","e","f");
  var array2 = new Array("c","e");
  for (var i = array1.length - 1; i >= 0; i--) {
    for (var j = 0; j < array2.length; j++) {
      if (array1[i] === array2[j]) {
        array1.splice(i, 1);
        }
      }
    }
    console.log(array1)
  }
Run Code Online (Sandbox Code Playgroud)

我怎么知道这个?请参阅以下内容:

for( var i =myArray.length - 1; i>=0; i--){
  for( var j=0; j<toRemove.length; j++){
    if(myArray[i] === toRemove[j]){
      myArray.splice(i, 1);
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

或者

var myArray = [
  {name: 'deepak', place: 'bangalore'}, 
  {name: 'chirag', place: 'bangalore'}, 
  {name: 'alok', place: 'berhampur'}, 
  {name: 'chandan', place: 'mumbai'}
];
var toRemove = [
  {name: 'deepak', place: 'bangalore'},
  {name: 'alok', place: 'berhampur'}
];

for( var i=myArray.length - 1; i>=0; i--){
    for( var j=0; j<toRemove.length; j++){
        if(myArray[i] && (myArray[i].name === toRemove[j].name)){
            myArray.splice(i, 1);
        }
    }
}

alert(JSON.stringify(myArray));
Run Code Online (Sandbox Code Playgroud)

关于这一点,有人能解释为什么外循环需要向下循环 (--)?

祝你好运!


小智 7

你可以试试这个

array1 = array1 .filter(val => {
             return !array2.find((val2)=>{
              //  console.log({valueID:val.id+":"+val2.id});
                return val.id===val2.id
             }) 
            });
Run Code Online (Sandbox Code Playgroud)


Fla*_*vio 6

使用 Set.prototype 构造函数:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Set

let array1 = Array('a', 'b', 'c', 'd', 'e', 'f')
let array2 = Array('c', 'e', 'g')
let concat = array1.concat(array2) // join arrays => [ 'a', 'b', 'c', 'd', 'e', 'f', 'c', 'e', 'g' ]

// Set will filter out duplicates automatically
let set = new Set(concat) // => Set { 'a', 'b', 'c', 'd', 'e', 'f', 'g' }

// Use spread operator to extend Set to an Array
let result = [...set]
console.log(result) // =>  [ 'a', 'b', 'c', 'd', 'e', 'f', 'g' ]
Run Code Online (Sandbox Code Playgroud)