配列に追加するために個別のキーと値のペアに変換する必要がある json データがあります。
jsonデータを個別のキーペアデータにする正しい方法は何でしょうか..?
ベストプラクティスを探しています。
ここに私のjsonがあります:
{
"DashBoard":[
{"title":"DashBoard"},
{"widget":[{"slide":"To do"},{"slide":"Teamspace"},{"slide":"Recent Activity"}]},
{"activity":[
{"option":[{"show":"Volvo"},{"show":"Benz"},{"show":"Honda"}]},
{"rows":[
{"row" : {"title":"Advert1", "text":"sample text1", "date":"22-06-2013"} }
,{"row" : {"title":"Advert2", "text":"sample text2", "date":"22-06-2014"} }
,{"row" : {"title":"Advert3", "text":"sample text3", "date":"22-06-2015"} }
,{"row" : {"title":"Advert4", "text":"sample text4", "date":"22-06-2016"} }
,{"row" : {"title":"Advert5", "text":"sample text5", "date":"22-06-2017"} }
]}
]}
]
}
私の出力は次のようになります。
var arr = [
{"title":"DashBoard"},
{"slide":"To do"},
{"slide":"Teamspace"},
{"slide":"Recent Activity"},
{"show":"Volvo"},
{"show":"Benz"},
{"show":"Honda"}
{"row" : {"title":"Advert1", "text":"sample text1", "date":"22-06-2013"},
{"row" : {"title":"Advert2", "text":"sample text2", "date":"22-06-2014"}
]
そのようです。
私は試してみます:
newObj = {
"title" : obj[0],
"widget" : obj[1]["widget"],
"option" : obj[2].activity[0]["option"],
"rows" : obj[2].activity[1]["rows"]
};
newObj = {
"title" : obj[0],
"widget" : obj[1]["widget"],
"option" : obj[2].activity[0]["option"],
"rows" : obj[2].activity[1]["rows"]
};
$.each(newObj, function(key, value){
if($.type(value) === "object"){
newColl.push(value);
}else if ($.type(value) === "array"){
_.each(value, function(i,v){
newColl.push(i);
})
}
})
しかし、最高の結果が得られるわけではありません。これを取得するためのより正しい方法を教えてくれる人はいますか? (基本的に、これをすべてバックボーンのモデルに変換しています)