解析JSON对象与字符串之间的相互转换


Posted in Javascript onDecember 18, 2013

在开发的过程中,如果对于少量参数的前后台传递,可以直接采用ajax的data函数,按json格式传递,后台Request即可,但有的时候,需要传递多个参数,这样后台

接受的时候Request多个很麻烦,此时要按照类的格式或者 集合的形式进行传递。

例如:前台按类的格式传递JSON对象:

var jsonUserInfo = "{\"TUserName\":\"" + userName + "\",\"TInterest\":\"" + interest + "\",\"TSex\":\"" + sex + "\",\"TCity\":\"" + city + "\",\"TDetail\":\"" + detail + "\"}";

如拼出的jsonUserInfo 无转义符号,需要var jsonArrayFinal = JSON.stringify(jsonArray);进行转换后再传递。

$.ajax(
                    {
                        type: "post",
                        url: "ReceiveHandler1.ashx",
                        data: { userInfo: jsonUserInfo, flag: "123456", key: "654321" },
                        dataType: "text",
                        success: function(data) {
                            $("#divShow").html(data);
                        }
 });

如果前台传递多个类格式的JSON数组,也就是集合类型:

例如:

[{"name":"a"},{"name","b"},{"name","c"}],则无法传递,此时必须使用JSON.stringify将数组对象转换成字符串,再进行AJAX传递即可。

比如我有两个变量,我要将a转换成字符串,将b转换成JSON对象:

var a={"name":"tom","sex":"男","age":"24"};
var b='{"name":"Mike","sex":"女","age":"29"}';

在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和parse()方法。

JSON.stringify(obj)将JSON转为字符串。JSON.parse(string)将字符串转为JSON格式;

上面的转换可以这么写:
var a={"name":"tom","sex":"男","age":"24"};
var b='{"name":"Mike","sex":"女","age":"29"}';
var aToStr=JSON.stringify(a);
var bToObj=JSON.parse(b);
alert(typeof(aToStr));  //string
alert(typeof(bToObj));//object

JSON.stringify()

ie8(兼容模式),ie7和ie6没有JSON对象,不过http://www.json.org/js.html提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;你可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。

ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象,

var c='{"name":"Mike","sex":"女","age":"29"}';
var cToObj=eval("("+c+")");
alert(typeof(cToObj));

jQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。当然如果有兴趣可以自己封装一个jQuery扩展,jQuery.stringifyJSON(obj)将JSON转为字符串。

Javascript 相关文章推荐
一份老外写的XMLHttpRequest代码多浏览器支持兼容性
Jan 11 Javascript
JQuery教学之性能优化
May 14 Javascript
JQuery插件Quicksand实现超炫的动画洗牌效果
May 03 Javascript
js实现精美的图片跟随鼠标效果实例
May 16 Javascript
jQuery CSS3自定义美化Checkbox实现代码
May 12 Javascript
Vue.js 和 MVVM 的注意事项
Nov 07 Javascript
Vue2递归组件实现树形菜单
Apr 10 Javascript
基于js 字符串indexof与search方法的区别(详解)
Dec 04 Javascript
利用10行js代码实现上下滚动公告效果
Dec 08 Javascript
AngularJS实时获取并显示密码的方法
Feb 06 Javascript
详解vue-cli脚手架中webpack配置方法
Aug 22 Javascript
解决vuejs项目里css引用背景图片不能显示的问题
Sep 13 Javascript
cookie中的path与domain属性详解
Dec 18 #Javascript
浅析Cookie中的Path与domain
Dec 18 #Javascript
jquery.cookie用法详细解析
Dec 18 #Javascript
Event altKey,ctrlKey,shiftKey属性解析
Dec 18 #Javascript
extjs4 treepanel动态改变行高度示例
Dec 17 #Javascript
Javascript浅谈之this
Dec 17 #Javascript
将list转换为json失败的原因
Dec 17 #Javascript
You might like
一个PHP日历程序
2006/12/06 PHP
PHPMailer邮件类利用smtp.163.com发送邮件方法
2008/09/11 PHP
php中Snoopy类用法实例
2015/06/19 PHP
PHP的Yii框架的常用日志操作总结
2015/12/08 PHP
PHP实现更改hosts文件的方法示例
2017/08/08 PHP
详解PHP队列的实现
2019/03/14 PHP
php正则表达式使用方法整理集合
2020/01/31 PHP
统一接口:为FireFox添加IE的方法和属性的js代码
2007/03/25 Javascript
把input初始值不写value的具体实现方法
2013/07/04 Javascript
IE8下Jquery获取select选中的值post到后台报错问题
2014/07/02 Javascript
jQuery中:focus选择器用法实例
2014/12/30 Javascript
js中的事件捕捉模型与冒泡模型实例分析
2015/01/10 Javascript
详细解读JavaScript编程中的Promise使用
2015/07/27 Javascript
谈谈JavaScript自定义回调函数
2015/10/18 Javascript
详解Node.js如何开发命令行工具
2016/08/14 Javascript
vue.js指令v-for使用及索引获取
2016/11/03 Javascript
Jil,高效的json序列化和反序列化库
2017/02/15 Javascript
简单谈谈axios中的get,post方法
2017/06/25 Javascript
详解express + mock让前后台并行开发
2018/06/06 Javascript
分享5个小技巧让你写出更好的 JavaScript 条件语句
2018/10/20 Javascript
微信小程序3种位置API的使用方法详解
2019/08/05 Javascript
vue解决使用$http获取数据时报错的问题
2019/10/30 Javascript
浅谈vue-router路由切换 组件重用挖下的坑
2019/11/01 Javascript
JavaScript Date对象功能与用法学习记录
2020/04/28 Javascript
Python使用MySQLdb for Python操作数据库教程
2014/10/11 Python
python获得一个月有多少天的方法
2015/06/04 Python
python计算auc指标实例
2017/07/13 Python
python实现二维数组的对角线遍历
2019/03/02 Python
Python列表切片常用操作实例解析
2019/12/16 Python
Wiggle澳大利亚:自行车、跑步、游泳商店
2020/11/07 全球购物
J2EE面试题集锦(附答案)
2013/08/16 面试题
生物化工专业个人自荐信
2013/09/26 职场文书
质检的岗位职责
2013/11/17 职场文书
房地产资料员岗位职责
2014/07/02 职场文书
再读《皇帝的新衣》的读后感悟!
2019/08/07 职场文书
SQL Server作业失败:无法确定所有者是否有服务器访问权限的解决方法
2021/06/30 SQL Server