如何比较两个数组,删除第二个数据中缺少的元素并推送差异

问题描述 投票:0回答:3

我有两个“门票”数组,我需要每3秒更新一次,问题是出于动画原因,我不能简单地覆盖第一个数组就像第二个数组一样。

像这样:

let array_1 = [1, 2, 3, 5]; //diff 3, 5
let array_2 = [1, 2, 6, 7]; //diff 6, 7

我需要的是比较两个数组,删除“3和5”并将“6和7”推到第一个数组,留下第一个数组如下:

array_1 = [1, 2, 6, 7];

怎么做到这一点?

[编辑]

为了澄清目的,我目前正在构建一个动态地图,每隔几秒就会收到一个新的信息,作为对象(这是比较中的痛苦)。

我不能有第三个数组或覆盖第一个数组,因为这样做会导致标记在地图上“闪烁”,所以我必须操纵第一个。

我在下面使用了@Andrew Yochum的回复来提出解决方案如下:

let array_1 = [
    {serial_number: 'abc', lat: 1, lng: 1},
    {serial_number: 'def', lat: 2, lng: 2},
    {serial_number: 'ghi', lat: 3, lng: 3},
];

let array_2 = [
    {serial_number: 'abc', lat: 1, lng: 1},
    {serial_number: 'def', lat: 2, lng: 2},
    {serial_number: 'jkl', lat: 4, lng: 4},
    {serial_number: 'mno', lat: 5, lng: 5},
];

let compare_1 = JSON.parse(JSON.stringify(array_1));
compare_1 = compare_1.map(el => JSON.stringify(el));

let compare_2 = JSON.parse(JSON.stringify(array_2));
compare_2 = compare_2.map(el => JSON.stringify(el));

let removeArray = [...compare_1.filter(i => !compare_2.includes(i))];
let addArray = [...compare_2.filter(i => !compare_1.includes(i))];

compare_1.forEach((first_el) => {
    removeArray.forEach((second_el) => {
        if(first_el == second_el){
            array_1.splice(compare_1.indexOf(first_el, 1));
        }
    });
});

addArray.forEach((element) => {
    array_1.push(JSON.parse(element));
});

有什么办法优化这个?

javascript node.js ecmascript-6
3个回答
2
投票

鉴于您需要就地编辑原始数组的新限制以及您提供的示例数据,这里是一个相当优化的解决方案,而无需您的解决方案利用的JSON编码/解码。没有制作新的阵列或副本。它还假设serial_number是一个唯一键,可用于在数组之间进行重复数据删除。

let array_1 = [
    {serial_number: 'abc', lat: 1, lng: 1},
    {serial_number: 'def', lat: 2, lng: 2},
    {serial_number: 'ghi', lat: 3, lng: 3},
]; //diff 'ghi'
let array_2 = [
    {serial_number: 'abc', lat: 1, lng: 1},
    {serial_number: 'def', lat: 2, lng: 2},
    {serial_number: 'jkl', lat: 4, lng: 4},
    {serial_number: 'mno', lat: 5, lng: 5},    
]; //diff 'jkl' 'mno'

function containsSerialNumber(array, serial_number) {
    for(let i = 0; i < array.length; i++) {
        if (array[i].serial_number === serial_number) {
            return true;
        }
    }
}

// removes 'ghi'
for (let i = 0; i < array_1.length; i++) {
    if (!containsSerialNumber(array_2, array_1[i].serial_number)) {
        array_1.splice(i,1);
        i--; // Adjust i down since we just edited in-place
    }
}

// add 'jkl' 'mno'
for (let i = 0; i < array_2.length; i++) {
    if (!containsSerialNumber(array_1, array_2[i].serial_number))
        array_1.push(array_2[i]);
}  

0
投票

let array_1 = [1, 2, 3, 5]; //diff 3, 5
let array_2 = [1, 2, 6, 7]; //diff 6, 7

for(var i = 0; i < array_1.length; i++){
  if(array_1[i] != array_2[i]){
    array_1[i] = array_2[i];
  }
}
console.log(array_1);

0
投票

基于你所说的“我需要的是比较两个数组,删除”3和5“并将”6和7“推到第一个数组”:

let array_1 = [1, 2, 3, 5]; //diff 3, 5
let array_2 = [1, 2, 6, 7]; //diff 6, 7

for(var i = 0; i < array_1.length; i++){

  if(array_1[i] != array_2[i]){
        array_1.splice(i,1,array_2[i]);
  }
}
console.log(array_1);
© www.soinside.com 2019 - 2024. All rights reserved.