首先,将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();
}