javascriptで2つの連想配列のマージを効率良く実行する方法を教えて下さい。
下記のソースコードでは
tempRowDataにrowDataを上書きしています。
実際のデータは最大1000行程度になります。
2つの連想配列の関係性は tempRowData >= rowData となります。
第1ループでmapを使用し、第2ループでsome(forEachでbreakができないための代用)をしています。
someで抜けたらそのrowDataの該当indexは次のtempRowDataのループで使用しないため削除しています。
Object.assignを使ってマージする方法もあるようですが、2つの合算になるだけのため使いませんでした。
仕様の説明を追加しました。
・tempRowDataに対してrowDataのidが合致する場合に上書きします。
・rowDataのidは常にtempRowDataに存在
・tempRowDataのidがrowDataに存在しないことがある(isDeleted: trueの場合に存在しない)
javascript
1var tempRowData = [ 2 {id: 1, text: "TEST1", isDeleted: false}, 3 {id: 2, text: "TEST2", isDeleted: false}, 4 {id: 3, text: "TEST3", isDeleted: true} 5]; 6 7var rowData = [ 8 {id: 1, text: "TEST1", isDeleted: false}, 9 {id: 2, text: "TEST4", isDeleted: false} 10]; 11 12if (rowData.length) { 13 var result = tempRowData.map((item) => { 14 var temp = null; 15 var tempIndex = null; 16 rowData.some((item2, index2) => { 17 if (item["id"] == item2["id"]) { 18 temp = item2; 19 tempIndex = index2; 20 return true; 21 } 22 }); 23 24 if (temp != null) { 25 rowData.splice(tempIndex, 1); 26 return temp; 27 } 28 29 return item; 30 }); 31 32 tempRowData = result; 33} 34 35/* 36 結果 37 tempRowData = [ 38 {id: 1, text: "TEST1", isDeleted: false}, 39 {id: 2, text: "TEST4", isDeleted: false}, 40 {id: 3, text: "TEST3", isDeleted: true} 41 ] 42*/
回答3件
あなたの回答
tips
プレビュー