您的位置:首页 > Web前端 > JavaScript

Linq to Json

2013-09-06 17:06 281 查看
原本感觉Newtonsoft.Json和.net自己的JavaScriptSerializer相差无几,所以将工程里的Json都换成了JavaScriptSerializer来实现,可是近几日遇到一个需求.在反序列化时我并没有预先定义好的类,而是要以字典形式读取.

于是我自己实现了一个类,由于没有模型对象,所以所有的Json读取和检测过程都要重新写过.

后来却发现Newtonsoft中已经提供了我需要的功能,甚至还提供了Json的Linq查询.

JObject

下面用个实例来搞定它的读写

1.Json是这样的

{title:123,body:456,list:{title:'这是一个标题',body:'what'}}

2.我要将其中几项都搞出来,代码:

staticvoidMain(string[]args)
{
stringstr="{title:123,body:456,list:{title:'这是一个标题',body:'what'}}";
JObjecto=JObject.Parse(str);
Console.WriteLine(o["title"]);
Console.WriteLine(o["body"]);
Console.WriteLine(o["list"]["title"]);
Console.WriteLine(o["list"]["body"]);
Console.ReadKey();
}

3.这样就输出了:

123
456
"这是一个标题"
"what"


不足:字符串还是案字符串输出带"",但我想这也不是问题.Trim就好了

LinqtoJson

基本Linq的都差不多,可以参考Json.net文档.这个并未深入研究

	stringstr="{title:123,body:456,list:{title:'这是一个标题',body:'what'}}";
JObjecto=JObject.Parse(str);

vars=
frompino.Children()
selectp;

foreach(varitemins)
{
Console.WriteLine(item);
}

Console.ReadKey();
http://www.360doc.com/content/11/0527/08/5054188_119690206.shtml
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: