首先,例如json数据如下书写:
1
2
3
4
|
{ "head" : [ { "text" : "广州" , "id" : "广州" , "pid" : "广东省" }, { "text" : "郑州" , "id" : "郑州" , "pid" : "河南省" }], } |
如上,倘若想将id和pid数据依次取出,就只能用循环,代码如下:
1
2
3
4
5
6
7
8
|
var head_id = "" ; var head_pid = "" ; for ( var i = 0; i < data.head.length; i++) { head_id += data.head[i].id + " " ; //循环输出json数据 head_pid += data.head[i].pid + " " ; } $( "#city" ).append( "city:" + head_id); $( "#city" ).append( "province:" + head_pid); |
这样,将会在data之后,依次输出json中的数据。
若想有选择性的输出时,需要添加if条件,代码如下:
1
2
3
4
5
|
for ( var i = 0; i < data.head.length; i++) { if (data.head[i].pid == "河南省" ) { //有选择的输出json数据 head_pid += data.head[i].pid; } } |
需要注意的是,倘若对象中有多组数据,则用data.head.id是undefined的,因为没有标明是哪组数据,例如data.head[0].id,若对象中只有一组数据,则可以直接用data.head.id输出。
另外,倘若调出来的json数据,中文乱码,一方面查看json调用的jquery代码,另一方面,可能是编写json数据的文件的问题。
以上是自学json的一点学习所得,记录一下。
(注:对象中多个数据时,直接使用)(注:对象中多个数据时,直接使用)