8

ネストされた 2 つの大きな、潜在的に非常に大きな JavaScript 配列。1 つは現在の配列で、もう 1 つはこの配列の以前の反復です。関数は、すべての異なる要素を見つけて、変更されたものに作用する必要があります。

これを行う関数を作成する方法を知っています。そのようなことを行うためのベストプラクティスは何なのか疑問に思っています。良いアドバイスをいただければ幸いです。さまざまな要素への応答を処理する jQuery でネイティブ JavaScript を使用することを検討しています。

この質問はいくつかのことを扱います。

  1. オブジェクトを比較する最も効率的な方法は何ですか。JavaScript チェックでは、if を介して、オブジェクトが別のオブジェクトと等しいか等しくない場合、たとえそれらが等しい場合でも、常にそうではないと言います。したがって、オブジェクトを分解して比較する必要があります。

  2. 結果を返す最良の方法は何ですか? 違いの配列を作成しますか?最初の配列を調べているときに、最初の配列と同じオブジェクトを消去しますか?それとも、まったく新しい配列を作成して返しますか?

4

2 に答える 2

1
function CompareArrays(arr1, arr2){    
    for(var key in arr1){
        if( arr1[key] !== arr2[key]){
            // traverse into nested array
            if(typeof(arr1[key]) == 'object' || typeof(arr2[key]) == 'object'){                
                CompareArrays( arr1[key], arr2[key]);
            }
        }else{
                delete arr2[key];
        }
    }
}

var a1 = [1,2,3,["a","b","c"],4,5,6,["d","e","f"]];
var a2 = [1,2,5445,["a","tt","c"],4,5,336,["d","edee","ffdf"], 'blablabla', 'I\'m extra'];

CompareArrays( a1, a2 );
console.log(a2);

これは、与えられた 2 番目を調べます。そして、共有されている等しい値を削除して変更します。配列はそのまま残りますが、同じだった値は未定義になります。

于 2013-05-14T14:14:00.297 に答える
0

個人的には、再帰はこの状況に適した方法だと思います。

console.clear();
// Compare 2 nested arrays, do something if values don't match
function CompareArrays(arr1, arr2){

    for(var i=0;i<arr1.length;i++){
        if( typeof arr1[i] === "object"){
            // traverse into nested array
            CompareArrays( arr1[i], arr2[i] );
        }else{
            if (arr1[i] != arr2[i]){
                // do something!
                console.log( "mismatch @ "+ i +" a1: "+arr1[i]+" a2: "+ arr2[i]);
            }
        }
    }
}

var a1 = [1,2,3,["a","b","c"],4,5,6,["d","e","f"]];
var a2 = [1,2,55,["a","tt","c"],4,5,6,["d","e","f"]];

CompareArrays( a1, a2);

作業フィドル: http://jsfiddle.net/ymSmP/5

于 2013-05-14T11:45:37.370 に答える