JavaScript配列をグループ化する
このようなJavaScript配列があるとします-
const data = [
{
"dataId": "1",
"tableName": "table1",
"column": "firstHeader",
"rows": [
"a","b","c"
]
},
{
"dataId": "2",
"tableName": "table1",
"column": "secondHeader",
"rows": [
"d","e","f",
]
}, {
"dataId": "3",
"tableName": "table2",
"column": "aNewFirstHeader",
"rows": [
1,2,3
]
}
]; そのような配列の1つにJavaScript関数を記述する必要があります。関数は、元の配列に基づいて、オブジェクトの新しいグループ化された配列を構築する必要があります。
グループ化された配列には、個別の一意の「tableName」オブジェクトのデータが含まれている必要があります。
したがって、最終的に、出力は次のようになります-
const output = [
{
"tableName": "table1",
"column": ["firstHeader", "secondHeader"],
"rows": [["a","b","c"], ["d","e","f"]]
},
{
"tableName": "table2",
"column": ["aNewFirstHeader"],
"rows": [[1,2,3]]
}
]; 例
const arr = [
{
"dataId": "1",
"tableName": "table1",
"column": "firstHeader",
"rows": [ "val","b","c" ]
},
{
"dataId": "2",
"tableName": "table1",
"column": "secondHeader",
"rows": [
"d","e","f",
]
},
{
"dataId": "3",
"tableName": "table2",
"column": "aNewFirstHeader",
"rows": [
1,2,3
]
}
];
const groupArray = (arr = []) => {
const res = arr.reduce((obj => (acc, val) => {
let item = obj.get(val.tableName);
if (!item) {
item = {
tableName: val.tableName, column: [], rows: []
}
obj.set(val.tableName, item); acc.push(item);
};
item.column.push(val.column); item.rows.push(val.rows);
return acc;
})(new Map), []);
return res;
};
console.log(JSON.stringify(groupArray(arr), undefined, 4)); 出力
そして、コンソールの出力は-
になります[
{
"tableName": "table1",
"column":
[
"firstHeader",
"secondHeader"
],
"rows": [
[
"val", "b", "c"
],
[
"d", "e", "f"
]
]
}, {
"tableName": "table2",
"column": [
"aNewFirstHeader"
],
"rows": [
[
1, 2, 3
]
]
}
] -
JavaScriptでの配列の分解。
破棄すると、配列から値が解凍されます。以下は、JavaScriptでの配列の非構造化のコードです- 例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <
-
JavaScriptでIDごとにオブジェクトの配列をグループ化する方法は?
以下は、JavaScriptでオブジェクトの配列をIDでグループ化するコードです- 例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style>