首先,将json串转为一个JObject对象:

JObject jo = (JObject)JsonConvert.DeserializeObject(CurrentSelectedItemReq)

这个JObject是一个“值对”类型,比如说我们的json串是这样:

{

"rows":[


[


{"NumIid":"001"},


{"PicUrl":"xxx.png"},


{"Title":"xxxxx"},


{"Price":"xxx"},


{"OuterId":"xxxx"} 


],


[


{"NumIid":"002"},


{"PicUrl":"xxx.png"},


{"Title":"xxxxx"},


{"Price":"xxx"},


{"OuterId":"xxxx"} 


],


[


{"NumIid":"003"},


{"PicUrl":"xxx.png"},


{"Title":"xxxxx"},


{"Price":"xxx"},


{"OuterId":"xxxx"} 


]


]

}

那么可以jo["rows"]就是一个数组,如果这个反之如果不是数组可能是一个对象,那么我们根据他实际是一个什么值来进行强制转换。

以上面这个json串为例,我们这样取到这个数组:

JArray arr = (JArray)jo["rows"];

我们发现这个数组里面还是一个数组,而里层数组里面才是一个object,那么我们可以这样取:

for (int i = 0; i < arr.Count; i++) 


{


JArray arr2 = (JArray)arr[i];


for (int j = 0; j < arr2.Count; j++) 


{


JObject obj = (JObject)arr2[j];

 

Response.Write(obj["NumIid"]);


Response.End();


}

 

}

如果实际是一个数组,我们就用JArray强制转换,如果实际是一个值对,我们就用JObject强制转换。

最后一层应该是一个值对类型的object,怎么把这些值全部取出来?

最后应该是形如:

{"NumIid":"003"}

取值很简单,直接:

string str=obj["NumIid"];

问题是有时候这个obj是这样的:

{"PicUrl":"xxx.png"}

而且你不知道他什么时候是什么。

这时应该这样取:

foreach (KeyValuePair<string, JToken> kp in obj) 


{


Response.Write(kp.Key);


Response.Write("=");


Response.Write(kp.Value);


Response.End();


}