
首先,将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();
}
|
以上这篇用Newtonsoft将json串转为对象的方法(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。