服务器端
LINQ to JSON
获取LINQ to JSON的开源资源,可以访问http://json.codeplex.com/。
如果仅使用,可以下载Newtonsoft.Json.dll。
在项目中引用Newtonsoft.Json.dll就可以获得LINQ to JSON的能力了。在下面的示例中,我使用到了Northwind数据库,使用LINQ to SQL方式读取所有产品类别数据,创建一个JObject对象:
|
using (NorthwindDataContext db = new NorthwindDataContext()) { JObject json = new JObject( //创建JSON对象 db.Categories.Select( c => new JProperty( //创建JSON属性 c.CategoryName, //属性名称(在这里是产品类别名称) new JArray( //属性的值(在这里是该类别下的所有产品名称) c.Products.Select( p => p.ProductName ) ) ) ) ); ltrJson.Text = json.ToString(); } |
上述代码生成的数据结构如下:
|
“类别名称” : [“产品名称”, “产品名称”, “产品名称”,…] , “类别名称” : [“产品名称”, “产品名称”, “产品名称”,…] ,…… |
在前台页面获取ltrJson.Text,然后调用JSON.parse(ltrJson.Text),就可以获取到生成的对象了。
可以看出,LINQ to JSON提供程序支持我们以习惯的LINQ方式读取、创建对象,简化了开发过程,让我们的注意力可以集中在业务流程上。
下面简单地介绍LINQ to JSON中常用的几个类。
|
LINQ to JSON |
JavaScript |
描述 |
|
JObject |
Object |
对象 |
|
JProperty |
string |
属性名 |
|
JArray |
Array |
数组 |
|
JValue |
string,number,object,array,true,false,null |
属性的值 |
使用LINQ to JSON创建的对象,都可以简单地调用ToString方法来获取JSON字符串。此方法有两个重载形式,第一个是无参形式,可以按照默认格式获取JSON字符串;也可以调用有参格式,使用自定义格式来生成JSON字符串。
将字符串转换为JObject对象
在后台程序中可以通过JObject的静态方法Parse将字符串转换为一个JObject对象:
|
JObject o = JObject.Parse(json); |
转换成功后,就可以利用LINQ to JSON的特性来进行相关操作了。
LINQ to JSON中的查询
要使用LINQ to JSON进行查询,就必须要了解它的数据结构:

可以看出,其所有的类都派生于JToken,也就是说所有的LINQ to JSON对象都可以用JToken来表示,即JObject、JProperty还是JArray都可以利用李氏替换原则而用JToken来表示。认清这一点是非常必要的,因为接下来的示例中将多次用到他们之间的类型转换。
遍历一个JToken中所包含的元素,可以使用JTokenObj. Children方法,例如:
|
using (ProductDataContext db = new ProductDataContext()) { JObject json = new JObject( //创建JSON对象 db.Categories.Select( c => new JProperty( //创建JSON属性 c.CategoryName, //属性名称(在这里是产品类别名称) new JArray( //属性的值(在这里是该类别下的所有产品名称) c.Products.Select( p => p.ProductName ) ) ) ) );
foreach (JProperty i in json.Children()) //遍历JSON对象的所有属性 { Console.WriteLine("类别为{0}的产品列表", i.Name); //输出属性的名称 JArray arr = (JArray)i.Value; //获取属性的值(在这里是该类别下的所有产品名称) foreach (JValue j in arr) //遍历产品名称集合 { Console.WriteLine(j.Value); //输出产品名称 } Console.WriteLine("-----------------------------------------------------"); } |
上述示例运行后,将输出所有的产品类别,以及属于对应类别的所有产品信息。
http://hi.baidu.com/wmeihan/blog/item/6da5bede03dd2a0b495403f0.html
浙公网安备 33010602011771号