[英]how to pull data with one common field and make nested array in javascript
如何使用一個公共字段提取數據並在javascript中制作嵌套的json
我有一個這樣的數組:
var arr = [{
"date" : "2021-07-01",
"Subject" : "Math",
"index" : 1
},{
"date" : "2021-07-02",
"Subject" : "Social",
"index" : 2
},{
"date" : "2021-07-01",
"Subject" : "Science",
"index" : 3
},{
"date" : "2021-07-02",
"Subject" : "Economics",
"index" : 4
},{
"date" : "2021-07-01",
"Subject" : "English",
"index" : 5
},{
"date" : "2021-07-02",
"Subject" : "Computer",
"index" : 6
}]
結果我想要一個這樣的數組
arr = [{
date: "2021-07-01",
data : [{subject : "Math", "index" : 1},{subject : "Science", "index" : 3},{subject : "English", "index" : 5}]
},{
date: "2021-07-02",
data : [{subject : "Social", "index" : 2},{subject : "Economics", "index" : 4},{subject : "Computer", "index" : 6}]
}]
這是我正在嘗試的
var checkData = [];
var resultArr;
for(var i=0; i<arr.length; i++){
if(checkData.indexOf(arr[0].date) !== -1) {
// not getting data
}else{
checkData.push(arr[0].date);
resultArr.date = arr[0].date;
resultArr.data = {"index" : arr[0].index, "subject" : arr[0].subject};
}
}
任何幫助我怎么能做到這一點。
// fetch unique dates
const uniqueDates = arr.reduce((acc, rec) => {
if(acc.includes(rec.date))
return acc;
return [...acc, rec.date]
}, [])
//build your object
const result = uniqueDates.reduce((acc, rec)=> {
const data = arr.filter(i => i.date === rec).map(i => {
delete i.date
return i
})
return [...acc, {date: rec, data}]
}, [])
console.log(JSON.stringify(result, 2, 2))
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.