引用System.Web.Entity.dll
public static string ToJSON(this object obj)
{
JavaScriptSerializer serializer = new JavaScriptSerializer();
return serializer.Serialize(obj);
}
这几天在做移动后台服务,由于移动端的流量比较小,所以需要尽量的减小传输的数据包的大小,开始用的传XML,由于webservice生成的XML会自带很多东西,这样无疑是没有必要的,经讨论,最后换成用Json传输数据。
既然是在.Net框架中用Json序列化,这里必然会用到Json.NET,当然,如果有闲心的话可以将对象构造成Json的格式。网上有很多Json.NET dll文件下载。
http://json.codeplex.com/Release/ProjectReleases.aspx
类库下载后,第一步就是引用,这里不多说,接下来是如何使用这个东西。
序列化的话,我们会用到Newtonsoft.Json.JsonConvert.SerializeObject(Object obj)这个东西,只要将对象传入方法就可以得到相应的Json语句。
很简单,这里贴一个在网上找的泛型的序列化方法。
/// <summary>
/// JSON序列化
/// </summary>
public static string JsonSerializer<T>(T t)
{
DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T));
MemoryStream ms = new MemoryStream();
ser.WriteObject(ms, t);
string jsonString = Encoding.UTF8.GetString(ms.ToArray());
ms.Close();
return jsonString;
}
/// <summary>
/// JSON反序列化
/// </summary>
public static T JsonDeserialize<T>(string jsonString)
{
DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T));
MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(jsonString));
T obj = (T)ser.ReadObject(ms);
return obj;
}
==========================================
将后台程序(如php)发送过来的json数据转化为javascript的数组或者对象的方法十分简单,代码如下:
1 |
// 假设后台发送的json数据为 '{a:2,b:1}' 存储于str中 |
2 |
var data = eval( '(' + str + ')' ); |
然而想将一个javascript对象转化为json格式的字符串却并不那么简单,特别是对象的属性值递归包含一个对象时(如 var obj={a:[2,3],b:{m:[3,4],n:2} } ),那么有没有什么方法将obj转化为json格式的字符串呢?
当然你可以自己写一个函数,递归遍历一个对象并将其转化为json格式的字符串,对于大部分人来说这有些困难并容易出错。幸好已经有人做好了这件事情,你只用包含一段javascript代码即可。
json2.js
使用方法:
04 |
<script src= "json2.js" ></script> |
06 |
var obj={a:[2,3],b:{m:[3,4],n:2} }; |
07 |
var jsonStr = JSON.stringify( obj ); |
09 |
//将显示 {"a":[2,3],"b":{"m":[3,4],"n":2}} |
假如有两个变量,我要将a转换成字符串,将b转换成JSON对象:
1 |
var a={ "name" : "tom" , "sex" : "男" , "age" : "24" }; |
2 |
var b= '{"name":"Mike","sex":"女","age":"29"}' ; |
在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和parse()方法。JSON.stringify(obj)将JSON转为字符串。JSON.parse(string)将字符串转为JSON格式;
上面的转换可以这么写:
1 |
var a={ "name" : "tom" , "sex" : "男" , "age" : "24" }; |
2 |
var b= '{"name":"Mike","sex":"女","age":"29"}' ; |
3 |
var aToStr=JSON.stringify(a); |
4 |
var bToObj=JSON.parse(b); |
5 |
alert( typeof (aToStr)); //string |
6 |
alert( typeof (bToObj)); //object |
JSON.stringify()
ie8(兼容模式),ie7和ie6没有JSON对象,不过http://www.json.org/提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;你可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象:
1 |
var c= '{"name":"Mike","sex":"女","age":"29"}' ; |
2 |
var cToObj=eval( "(" +c+ ")" ); |
jQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。当然如果有兴趣可以自己封装一个jQuery扩展,jQuery.stringifyJSON(obj)将JSON转为字符串。
JSON.stringify(jsonobj),本来是最简便的方法,可是存在浏览器兼容问题(仅适用于IE8+,Chrome 1+,FF 3+)。下面再介绍一个方法:
01 |
var O2String = function (O) { |
02 |
//return JSON.stringify(jsonobj); |
06 |
if (Object.prototype.toString.apply(O) === '[object Array]' ) { |
07 |
for ( var i = 0; i < O.length; i++) |
08 |
S.push(O2String(O[i])); |
09 |
J = '[' + S.join( ',' ) + ']' ; |
11 |
else if (Object.prototype.toString.apply(O) === '[object Date]' ) { |
12 |
J = "new Date(" + O.getTime() + ")" ; |
14 |
else if (Object.prototype.toString.apply(O) === '[object RegExp]' || Object.prototype.toString.apply(O) === '[object Function]' ) { |
17 |
else if (Object.prototype.toString.apply(O) === '[object Object]' ) { |
19 |
O[i] = typeof (O[i]) == 'string' ? '"' + O[i] + '"' : ( typeof (O[i]) === 'object' ? O2String(O[i]) : O[i]); |
20 |
S.push(i + ':' + O[i]); |
22 |
J = '{' + S.join( ',' ) + '}' ; |
使用方法也很简单:
01 |
var jsonStr = O2String( |
08 |
"ItemName" : "CustomLabel1" , |
11 |
"ItemDate" : new Date(1320774905467), |
12 |
"ItemReg" : /[\w]*?/gi, |
13 |
"ItemFunc" : function () { alert( "ItemFunc" ); } |
16 |
"ItemName" : "CustomLabel1" , |
19 |
"ItemDate" : new Date(1320774905467), |
20 |
"ItemReg" : /[\w]*?/gi, |
21 |
"ItemFunc" : function () { alert( "ItemFunc" ); } |
30 |
"ItemName" : "CustomLabel2" , |
33 |
"ItemDate" : new Date(1320774905467), |
34 |
"ItemReg" : /[\w]*?/gi, |
35 |
"ItemFunc" : function () { alert( "ItemFunc" ); } |
38 |
"ItemName" : "CustomLabel2" , |
41 |
"ItemDate" : new Date(1320774905467), |
42 |
"ItemReg" : /[\w]*?/gi, |
43 |
"ItemFunc" : function () { alert( "ItemFunc" ); } |
50 |
var jsonObj = eval( "(" + jsonStr + ")" ); |
51 |
alert(jsonObj.length); |
最新文章
- JavaScript Array对象
- substring()
- (二)catalina.bat
- sqlplus实现上下翻页设置
- [Architect] Abp 框架原理解析(3) DynamicFilters
- Windows 10 下ASP.NET4.0尚未在Web服务器上注册
- 原创Java版的Shell
- MIME 部分扩展名与类型对应
- struts2请求过程源码分析(转)
- 详解CSS选择器、优先级与匹配原理
- 总结:spring 的ioc 知识点
- 调用ShellExecute所须要头文件
- html5笔记——<;section>; 标签
- gulp源码解析(一)—— Stream详解
- linux下编译visp库
- 基于IntelliJ IDEA开发工具搭建SSM框架并实现页面登录功能详细讲解二
- 你所不了解的javascript操作DOM的细节知识点(一)
- hdu 3038 给区间和,算出多少是错的
- JS面试Q&;A(续):Javascript数组排序, 默认是字符串Unicode排序, 不适合数字
- python高并发和多线程的关系
热门文章
- Oracle用户密码过期和用户被锁解决方法
- Spring中常用类型的bean配置(Map,List,Set,基本类型)
- makefile之变量赋值
- Chrome浏览器设置默认编码
- ik扩展支持Solr配置
- OpenStack 企业私有云的若干需求(2):自动扩展(Auto-scaling) 支持
- 输入url到页面返回的过程
- BZOJ3223: Tyvj 1729 文艺平衡树 [splay]
- ThinkPHP常用查询
- maven更改编译环境的java版本