json对象与字符串相互转换

JSON 语法
JSON 语法规则
- 对象表示为键值对
- 数据由逗号分隔
- 花括号保存对象
- 方括号保存数组
JSON 键/值对
1
|
{"firstName": "Json"} |
1
|
{firstName : "Json"} |
JSON 与 JS 对象的关系
1
|
var obj = {a: 'Hello' , b: 'World' }; //这是一个对象,注意键名也是可以使用引号包裹的 |
1
|
var json = '{"a": "Hello", "b": "World"}' ; //这是一个 JSON 字符串,本质是一个字符串 |
JSON 和 JS 对象互转
|
var json = JSON.stringify({a: 'Hello' , b: 'World' }); //结果是 '{"a": "Hello", "b": "World"}' |
|
var obj = JSON.parse( '{"a": "Hello", "b": "World"}' ); //结果是 {a: 'Hello', b: 'World'} |
- //使用json中的parser方法转换;
- var str='{"name":"fendouer", "age":23}'; //这是一个json字符串''
- var ob=JSON.parse(str) ; //返回一个新对象
- console.log(ob.name)
- //把json中的stringify对象转换成字符串
- var obj={"student":[{"name":"cyl","age":"21"},{"name":"hyj","age":"23"}]}; //这是一个json对象
- var str=obj.student[0].name;
- var newstr=JSON.stringify(str); //返回一个新字符串
- console.log(newstr);

在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();

扩展:
jquery中也有将字符串转为JSON格式的方法jquery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。当然如果有兴趣可以自己封装一个jquery扩展,jQuery.stringifyJSON(obj)将JSON转为字符串。
这只是一种方法,还有几种方法,大家可以看一下:
1) jquery插件支持的转换方式:
$.parseJSON( jsonstr );
//jquery.parseJSON(jsonstr), 可以将json字符串转换成json对象。

- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <title>json字符串转为json对象-jQuery.parseJSON()</title>
- <style type="text/css">
- p{
- white-space: pre-line;
- font-size: 20px;
- }
- </style>
- </head>
- <body>
- <p><a href="http://www.css88.com/jqapi-1.9/jQuery.parseJSON/">资源链接:http://www.css88.com/jqapi-1.9/jQuery.parseJSON/</a></p>
- <p>jQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。</p>
- <p>
- 描述: 接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript 值。
- 从jQuery 3.0开始,不推荐使用$.parseJSON。 要解析JSON字符串,请改用原生的 JSON.parse 方法。
- 传入格式有误的 JSON 字符串可能导致抛出异常。例如,下面这些无效的 JSON 字符串:
- ---------------------------------------------------
- {test: 1} (test 没有使用双引号包裹).
- {'test': 1} ('test' 用了单引号而不是双引号包裹).
- "{test: 1}" (test 没有使用双引号包裹).
- "{'test': 1}" ('test' 用了单引号而不是双引号包裹).
- "'test'" ('test' 用单引号代替双引号).
- ".1" (number 必须以数字开头; "0.1" 将是有效的).
- "undefined" (undefined 不能表示一个 JSON 字符串; 然而null,可以).
- "NaN" (NaN 不能表示一个 JSON 字符串; 用Infinity直接表示无限也是不允许的).
- ---------------------------------------------------
- JSON标准不允许“控制字符”如制表符或换行符。
- 比如$.parseJSON('{"testing":"1\t2\n3"}'),大多数实现中将抛出一个错误,因为JavaScript分析器直接转换字符串的制表符和换行符为文本的制表符和换行符;
- 产生双反斜杠,例如"1\\t2\\n3"是预期的结果。
- 这个问题往往在服务器端语言,如PHP,JSON注入到一个JavaScript文件时发生。
- 如果浏览器实现了原生的 JSON.parse, jQuery 则会使用它来解析字符串。
- 在jQuery 1.9之前,如果传递给$.parseJSON一个空字符串,null, 或者 undefined,,将返回null,而不是抛出一个错误,即使这些都不是有效的JSON。
- jQuery 3.0开始,$.parseJSON已经过时(不建议使用)。要将字符串解析成JSON对象,请使用原生的JSON.parse方法来代替。
- </p>
- <script src="js/jquery-2.1.0.js"></script>
- <script type="text/javascript">
- //解析一个 JSON 字符串。
- var d = '{"name":"郑秀晶","sex":"女","age":"23","height":"165","weight":"95g"}';
- console.log(d) //
- console.log(typeof(d)) //string
- var obj = jQuery.parseJSON(d);
- console.log(obj) //
- console.log(typeof(obj)) //object
- console.log( obj.name ); //郑秀晶
- </script>
- </body>
- </html>

2) 兼容:浏览器支持的转换方式(Firefox,chrome,opera,safari,ie9,ie8)等浏览器:
JSON.parse(jsonstr); //可以将json字符串转换成json对象
JSON.stringify(jsonobj); //可以将json对象转换成json对符串
注:ie8(兼容模式),ie7和ie6没有JSON对象,推荐采用JSON官方的方式,引入json.js。
3) JSON官方的转换方式:
http://www.json.org/ 提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;
可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。
4) Javascript支持的转换方式(eval):
eval('(' + jsonstr + ')'); //可以将json字符串转换成json对象,注意需要在json字符外包裹一对小括号
注:ie8(兼容模式),ie7和ie6也可以使用eval()将字符串转为JSON对象,但不推荐这些方式,这种方式不安全eval会执行json串中的表达式。

- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <title>string转object-兼容低版本浏览器(eval实现)</title>
- </head>
- <body>
- <p style="white-space: pre-line; font-size: 18px;">
- 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对象,
- eval("("+c+")")
- </p>
- <!--兼容ie6/7/8--引入json2.js文件-->
- <script src="js/json2.js"></script>
- <script type="text/javascript">
- var c='{"name":"郑秀晶","sex":"女","age":"23","height":"165","weight":"95g"}';
- console.log(c);
- console.log(typeof(c)); //string
- var cToObj=eval("("+c+")");
- console.log(typeof(cToObj)); //object
- </script>
- </body>
- </html>

json对象与字符串相互转换的更多相关文章
- js JSON对象与字符串相互转换
从服务器接收到数据一般是字符串的形式.如果是JSON格式的字符串,就需要先将其转换成JSON对象.JSON对象在浏览器输出为objcet,我们看不到具体的数据.所以将JSON对象转换成字符串. 下面将 ...
- JSON对象与XML相互转换工具类
依赖jar <dependency> <groupId>dom4j</groupId> <artifactId>dom4j</artifactId ...
- json对象与string相互转换教程
一.说明 1.1 背景说明 json对象与string相互转换,这东西想写了很多次,但总觉得网上教程比较成熟,所以之前每次都放弃了.但今天又被string转json对象折腾了半天,实在受不了,所以还是 ...
- js中的json对象和字符串之间的转化
字符串转对象(strJSON代表json字符串) var obj = eval(strJSON); var obj = strJSON.parseJSON(); var obj = JSO ...
- json对象转字符串与json字符串转对象
1.概述: 我们在编程时进场会遇到json对象转字符串,或者字符串转对象的情况. 2.解决办法: json.parse()方法是将json字符串转成json对象. json.stringfy()方法是 ...
- json对象与字符串的相互转换,数组和字符串的转换
1.json对象转换为字符串 JSON.stringify(value [, replacer] [, space]) var student = new Object(); student.id ...
- json对象和字符串的相互转换
JSON.stringify(obj) 将JSON对象转为字符串. JSON.parse(string) 将字符串转为JSON对象格式. 后台给你数据的时候,有时候会给你字符串 ...
- jquery转换json对象为字符串
jquery转换json对象为字符串 JSON.stringify(jsonObject),可用于单个JSON对象,也可用于JSON数组 alert(JSON.stringify(jsonObject ...
- jquery,字符串转json对象,json对象转字符串
字符串转json对象 方法一:var json = eval('(' + str + ')'); 方法二:return JSON.parse(str); json对象转字符串 JSON.stringi ...
随机推荐
- thinkphp3.2.3 ueditor1.4.3 图片上传操作,在线删除上传图片功能。
最近弄一个图片 上传,可是用ueditor 自带的上传,如果不配置的话,上传的目录不在自己的项目中. 在网上找了好多,可是都是底版本的,新版本的还真是找到了一个,ueditor-thinkphp 这个 ...
- Linux 启动盘命令
linux下有很多工具可以制作启动盘, 例如 unetbootin 和 wubi, 不过我们可以使用linux下的一条命令来完成-----dd 操作方法: 1 卸载你的U盘 假设你的u盘对应的设备是s ...
- 通过一个例子,总结下检测数组属性的N种方法
判断arr数组里是否含有a,有a返回1;没有返回2var arr = [{a:1,b:2,c:3},{q:1,w:2,e:3},{s:4,g:5,i:9},{b:2,v:3,u:4}]; 检测属性的3 ...
- 简简单单谈WCF
另一个系统去访问另一个系统,就是需要使用到分布式通讯咯.. 1. webService .netfromwork3.5中存在 2. webapi 3. Wcf scop通讯协议 以上三种都是 ...
- spring boot Configuration Annotation Proessor not found in classpath
出现spring boot Configuration Annotation Proessor not found in classpath的提示是在用了@ConfigurationPropertie ...
- input输入框不能获得焦点
今天在ipad上遇到一个问题:jquery 调用 $(id).focus() 方法,失效,不能弹出键盘获得输入的焦点. 开始以为是 $(id).focus() 方法的问题,然后就试着用原声的docum ...
- 【Android学习入门】Android studio基本设置
1.背景设置 依次选择File->Settings-->Appearance & Behaviour->Apprearance,然后勾选 show line number. ...
- 《ArcGIS Runtime SDK for Android开发笔记》——(3)、ArcGIS Runtime SDK概述
1.前言 ArcGIS Runtime SDK是一整套用于构建原生及跨平台的地图应用程序的开发包,包括移动设备的Android.iOS.Windows Phone,针对桌面的.Net.Java.OSX ...
- arm寄存器解析
寒假闲来无事准备将自己的走过的arm之路总结一下,今天就先从arm的寄存器说起吧,欢迎各位拍砖. 要介绍arm寄存器之前我们要先了解一下arm处理器的工作模式: Arm处理器有七种工作模式,为的是形成 ...
- HCNA配置console线路密码aaa认证
Please check whether system data has been changed, and save data in time Configuration console time ...