JSONでオブジェクトをネストする方法はありますか?すべてを配列する必要はありませんか?エラーなしでオブジェクトを解析するには、次のような構造が必要なようです。
{"data":[{"stuff":[
{"onetype":[
{"id":1,"name":"John Doe"},
{"id":2,"name":"Don Joeh"}
]},
{"othertype":[
{"id":2,"company":"ACME"}
]}]
},{"otherstuff":[
{"thing":
[[1,42],[2,2]]
}]
}]}
このオブジェクトを「結果」という変数にフェッチする場合、次のようにネストされたオブジェクトにアクセスする必要があります。
result.data[0].stuff[0].onetype[0]
そして
result.data[1].otherstuff[0].thing[0]
これは私にとって不器用で冗長なようですが、可能であれば私は好むでしょう:
result.stuff.onetype[0]
そして
result.otherstuff.thing
しかし、すべてが配列である場合、どのようにオブジェクトキーを直接使用できますか?私の混乱して教育されていない心には、このようなものがより適切に思えます:
{"data":
{"stuff":
{"onetype":[
{"id":1,"name": ""},
{"id":2,"name": ""}
]}
{"othertype":[
{"id":2,"xyz": [-2,0,2],"n":"Crab Nebula","t":0,"c":0,"d":5}
]}
}
{"otherstuff":
{"thing":
[[1,42],[2,2]]
}
}
}
私はおそらくここで基本的な何かを誤解しているでしょうが、2番目のスタイルオブジェクトを受け入れるjQueryパーサー(jQuery 1.4で使用されるネイティブFFパーサー)を取得することはできません。誰かが私を啓発できれば、ありがたいことに感謝します!
配列を使用する必要はありません。
JSON値は、配列、オブジェクト、またはプリミティブ(数値または文字列)にすることができます。
JSONは次のように記述できます。
{
"stuff": {
"onetype": [
{"id":1,"name":"John Doe"},
{"id":2,"name":"Don Joeh"}
],
"othertype": {"id":2,"company":"ACME"}
},
"otherstuff": {
"thing": [[1,42],[2,2]]
}
}
次のように使用できます。
obj.stuff.onetype[0].id
obj.stuff.othertype.id
obj.otherstuff.thing[0][1] //thing is a nested array or a 2-by-2 matrix.
//I'm not sure whether you intended to do that.
すべてのオブジェクトには、親オブジェクト内で名前を付ける必要があります。
{ "data": {
"stuff": {
"onetype": [
{ "id": 1, "name": "" },
{ "id": 2, "name": "" }
],
"othertype": [
{ "id": 2, "xyz": [-2, 0, 2], "n": "Crab Nebula", "t": 0, "c": 0, "d": 5 }
]
},
"otherstuff": {
"thing":
[[1, 42], [2, 2]]
}
}
}
したがって、次のようなオブジェクトを宣言することはできません。
var obj = {property1, property2};
でなければならない
var obj = {property1: 'value', property2: 'value'};
JSONデータ内に冗長なネストされた配列が多すぎますが、情報を取得することは可能です。他の人が言ったように、あなたはそれをきれいにしたいと思うかもしれません。
each()は、最後の配列まで別のeach()内でラップします。
jQueryのresult.data[0].stuff[0].onetype[0]
の場合、次のことができます。
`
$.each(data.result.data, function(index0, v) {
$.each(v, function (index1, w) {
$.each(w, function (index2, x) {
alert(x.id);
});
});
});
`