引用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); |
-
XE3随笔6:SuperObject 的 JSON 对象中还可以包含 ";方法";
SuperObject 的 JSON 对象中还可以包含 "方法", 这太有意思了; 其方法的格式是: procedure Method(const This, Params: IS ...
-
url地址数据参数转化JSON对象(js三种方法实现)
当我们用get方法提交表单时,在url上会显示出请求的参数组成的字符串,例如:http://localhost:3000/index.html?phone=12345678901&pwd=12 ...
-
json对象与字符串互转方法
字符串转json对象: var data = eval( '(' + str + ')' ); json对象转字符串: var jsonStr = JSON.stringify( obj );
-
JSON对象的stringify()和parse()方法
1.stringify() ---- JavaScript对象序列化为JSON字符串 eg1. var book = {title: 'JS', authors: ['Van'], edition:3 ...
-
JSON对象及方法
1.JSON JSON 包括 JSON 字符串和 JSON 对象.JSON 通常用于与服务端交换数据,在给服务器接收和发送数据时用的都是字符串,可以是 JSON 字符串或者一般的键值对字符串.把Jav ...
-
json对象转为字符串,当做参数传递时加密解密
[son对象 字符串 互相转行] 比如我有两个变量,我要将a转换成字符串,将b转换成JSON对象: var a={"name":"tom","sex ...
-
前台 JSON对象转换成字符串 相互转换 的几种方式
在最近的工作中,使用到JSON进行数据的传递,特别是从前端传递到后台,前台可以直接采用ajax的data函数,按json格式传递,后台Request即可,但有的时候,需要传递多个参数,后台使用requ ...
-
(77)Wangdao.com第十五天_JavaScript 用于数据交换的文本格式 JSON 对象
JSON 对象 JSON (JavaScript Object Notation 的缩写) 也是一种数据,是 JavaScript 的原生对象,用来处理 JSON 格式数据.它有两个静态方法:JSON ...
-
第168天:json对象和字符串的相互转换
json对象和字符串的相互转换 1.json对象和字符串的转换 在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和pa ...
随机推荐
-
PHP编码规范PSR-1
.note-content { font-family: "Helvetica Neue", Arial, "Hiragino Sans GB", STHeit ...
-
Linux模块机制浅析
Linux模块机制浅析 Linux允许用户通过插入模块,实现干预内核的目的.一直以来,对linux的模块机制都不够清晰,因此本文对内核模块的加载机制进行简单地分析. 模块的Hello World! ...
-
QT
http://www.cnblogs.com/csulennon/p/4483711.html
-
解决ADB端口占用问题
方式一5037为adb默认端口,若5037端口被占用,查看占用端口的进程PIDC:\Users\wwx229495>netstat -aon|findstr 5037 TCP 127. ...
-
RPC远程过程调用协议
最近学习Hadoop.Hbase.Spark及Storm原理,经常会出现RPC这样的传输术语,为了更好地理解,将知识点详细的整理下吧~ RPC-----它是一种通过网络从远程计算机程序上请求服务,而不 ...
-
转: html表单中get方式和post方式的区别
1.Get是用来从服务器上获得数据,而Post是用来向服务器上传递数据. 2.Get将表单中数据的按照variable=value的形式,添加到action所指向的URL后面,并且两者使用“?”连接 ...
-
Tomcat无法安装 Check your settings and permissions Ignore and continue anyway
刚刚“sj”,把装在C盘的tomcat的文件夹给删除了,刚删完就想到干嘛不卸载啊,哎惯性思维啊,转而一想,tomcat这么简单安装,不怕不怕,后来一装,妈啊,装不了,百度之后原来是服务没有删除,好吧, ...
-
mouseover和this的巧用
mouseover & mouseout 的问题 在JS中,使用mouseover & mouseout会有触发多次的问题,这里Jquery有了替代的新属性 mouseover == ...
-
Linux环境下使用Android NDK编译c/c++生成可执行文件
1.安装Android NDK至Linux(Lubuntu 16) 从网上下载 android-ndk-r13b-linux-x86_64.zip,本人将其解压至/home/guanglun/work ...
-
TVS(瞬间电压抑制器)
1.原理 TVS二极管在线路板上与被保护线路并联,当瞬时电压超过电路正常工作电压后,TVS二极管便产生雪崩,提供给瞬时电流一个超低电阻通路,其结果是瞬时电流透过二极管被引开,避开被保护元件,并且在电压 ...