第168天:json对象和字符串的相互转换

半指温柔乐      2022-02-17     124

关键词:

json对象和字符串的相互转换

1、json对象和字符串的转换

在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()parse()方法。
JSON.stringify(obj)       将JSON对象转为字符串
JSON.parse(string)       将字符串转为JSON对象格式。

 1 //使用json中的parser方法转换;
 2 
 3 var str=‘{"name":"fendouer", "age":23}‘;      //这是一个json字符串‘‘
 4 var ob=JSON.parse(str) ;  //返回一个新对象
 5 console.log(ob.name)
 6 
 7 
 8 //把json中的stringify对象转换成字符串 
 9 
10 var obj={"student":[{"name":"cyl","age":"21"},{"name":"hyj","age":"23"}]};      //这是一个json对象
11 var str=obj.student[0].name;
12 var newstr=JSON.stringify(str); //返回一个新字符串
13 console.log(newstr);

 

简单例子:

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 
7 JSON.stringify();

扩展:

jquery中也有将字符串转为JSON格式的方法jquery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。
这只是一种方法,还有几种方法,大家可以看一下:


1) jquery插件支持的转换方式:

$.parseJSON( jsonstr );

//jquery.parseJSON(jsonstr), 可以将json字符串转换成json对象。

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="UTF-8">
 5         <title>json字符串转为json对象-jQuery.parseJSON()</title>
 6         <style type="text/css">
 7             p{
 8                 white-space: pre-line;
 9                 font-size: 20px;
10             }
11         </style>
12     </head>
13     <body>
14         <p><a href="http://www.css88.com/jqapi-1.9/jQuery.parseJSON/">资源链接:http://www.css88.com/jqapi-1.9/jQuery.parseJSON/</a></p>
15         <p>jQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。</p>
16         <p>
17             描述: 接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript 值。
18             
19             从jQuery 3.0开始,不推荐使用$.parseJSON。 要解析JSON字符串,请改用原生的 JSON.parse 方法。
20             
21             传入格式有误的 JSON 字符串可能导致抛出异常。例如,下面这些无效的 JSON 字符串:
22             ---------------------------------------------------
23             {test: 1} (test 没有使用双引号包裹).
24             {‘test‘: 1} (‘test‘ 用了单引号而不是双引号包裹).
25             "{test: 1}" (test 没有使用双引号包裹).
26             "{‘test‘: 1}" (‘test‘ 用了单引号而不是双引号包裹).
27             "‘test‘" (‘test‘ 用单引号代替双引号).
28             ".1" (number 必须以数字开头; "0.1" 将是有效的).
29             "undefined" (undefined 不能表示一个 JSON 字符串; 然而null,可以).
30             "NaN" (NaN 不能表示一个 JSON 字符串; 用Infinity直接表示无限也是不允许的).
31             ---------------------------------------------------
32             
33             JSON标准不允许“控制字符”如制表符或换行符。
34             比如$.parseJSON(‘{"testing":"1	2
3"}‘),大多数实现中将抛出一个错误,因为JavaScript分析器直接转换字符串的制表符和换行符为文本的制表符和换行符; 
35             产生双反斜杠,例如"1\t2\n3"是预期的结果。
36             这个问题往往在服务器端语言,如PHP,JSON注入到一个JavaScript文件时发生。
37             
38             如果浏览器实现了原生的 JSON.parse, jQuery 则会使用它来解析字符串。
39             
40             在jQuery 1.9之前,如果传递给$.parseJSON一个空字符串,null, 或者 undefined,,将返回null,而不是抛出一个错误,即使这些都不是有效的JSON。
41             
42             jQuery 3.0开始,$.parseJSON已经过时(不建议使用)。要将字符串解析成JSON对象,请使用原生的JSON.parse方法来代替。
43             
44         </p>
45         <script src="js/jquery-2.1.0.js"></script>
46         <script type="text/javascript">
47             //解析一个 JSON 字符串。
48             var d = {"name":"郑秀晶","sex":"女","age":"23","height":"165","weight":"95g"};
49             console.log(d)      //
50             console.log(typeof(d))         //string
51             
52             var obj = jQuery.parseJSON(d); 
53             console.log(obj)          //
54             console.log(typeof(obj))       //object
55             
56             console.log( obj.name );      //郑秀晶
57             
58         </script>
59     </body>
60 </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串中的表达式。

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="UTF-8">
 5         <title>string转object-兼容低版本浏览器(eval实现)</title>
 6     </head>
 7     <body>
 8         <p style="white-space: pre-line; font-size: 18px;">
 9         ie8(兼容模式),ie7和ie6没有JSON对象,不过http://www.json.org/提供了一个json.js,
10         这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;
11         你可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。
12 
13         ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象,
14         eval("("+c+")")
15         </p>
16         
17         <!--兼容ie6/7/8--引入json2.js文件-->
18         <script src="js/json2.js"></script>
19         <script type="text/javascript">
20             
21             var c={"name":"郑秀晶","sex":"女","age":"23","height":"165","weight":"95g"};
22             console.log(c);
23             console.log(typeof(c));  //string
24             
25             var cToObj=eval("("+c+")");
26             console.log(typeof(cToObj));       //object
27             
28         </script>
29     </body>
30 </html>

 












js中实现json对象和json字符串之间的相互转换

...了JSON对象,其中的parse和stringify方法实现了JSON对象和JSON字符串之间的相互转换,例如://JSON对象转JSON字符串,输出:"{"name":"zhangsan","age":10,"birthday":"2017-08-15T07:09:48.7 查看详情

json对象和字符串之间的相互转换

比如有两个变量,我要将a转换成字符串,将b转换成JSON对象: vara={"name":"tom","sex":"男","age":"24"}; varb=‘{"name":"Mike","sex":"女","age":"29"}‘;在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和parse( 查看详情

json对象与字符串的相互转换,数组和字符串的转换

1.json对象转换为字符串JSON.stringify(value[,replacer][,space]) varstudent=newObject();student.id="001";student.name="程陈";student.age="18";varstr=JSON.stringify(student);//{"id":"001","name":"程陈","age":"1 查看详情

java里面json和java对象之间的相互转换

1.把java对象列表转换为json对象数组,并转为字符串    JSONArrayarray= JSONArray.fromObject(list);    Stringjsonstr=array.toString(); 2.把java对象转换成json对象,并转化为字符串   查看详情

json对象和字符串之间的相互转换(代码片段)

例子:1,newFunction形式functionstrToJson(str)varjson=(newFunction("return"+str))();returnjson;2,使用全局的JSON对象。JSON.stringify(obj)将JSON对象转为字符串。JSON.parse(string)将字符串转为JS 查看详情

数据集和json相互转换

...类似。这也是它们能序列一切对象的奥秒所在。JSON就是字符串,定义好序列后的字符串格式,甚至都不需要啥JSON类库,就可以自行组装JSON字符串和解析JSON字串获 查看详情

数据集和json相互转换

...类似。这也是它们能序列一切对象的奥秒所在。JSON就是字符串,定义好序列后的字符串格式,甚至都不需要啥JSON类库,就可以自行组装JSON字符串和解析J 查看详情

javascript之json[4]parse()和stringify()-json字符串和javascript对象数据之间的相互转换

JavaScript之JSON[4]parse()和stringify()-JSON字符串和JavaScript对象数据之间的相互转换1、JSON.parse()JSON.parse()方法用于将一个JSON字符串解析为一个JavaScript对象。JSON字符串必须使用双引号包括属性名和字符串值,不能使用单引号或无引号。... 查看详情

c#对象与json字符串的相互转换

程序使用.NETFramework提供的JavaScriptSerializer类进行序列化和反序列化操作,需要引用.NETFramework中的System.Web.Extensions程序集。对于直接进行DataTable类型对象的转换会出现“序列化类型为“System.Reflection.RuntimeModule”的对象时检测到循... 查看详情

mui:字符串和json数据的相互转换

JSON.parse()--字符串转换json、JSON.stringify()--json转换成字符串 如:收到Json对象:response,则:{"result":"aaa","bbb","ccc"}1.response=JSON.stringify(response);respnoseEl.innerHTML=response;   //则会显示js 查看详情

javascriptjson字符串与对象相互转换

...json格式,但是前端接收数据时,却时而是object,时而是字符串,令人百思不得其解。具体原因我还不是很清楚。在数据传输过程中,json是以文本,即字符串的形式传递的, 查看详情

json字符串与json对象的相互转换

...言和平台。JSON解析器和JSON库支持许多不同的编程语言JSON字符串:varstr=‘{"name":"zwq","se 查看详情

javascript中json对象和json字符串的相互转化

一、JSON字符串转换为JSON对象varstr=‘{"name":"cxh","sex":"man","age":"25"}‘;//方法一:eval方式解析varobj1=eval(‘(‘+str+‘)‘);console.log(obj1.name);//方法二:使用全局的JSON对象解析,使用JSON.parse需严格遵守JSON规范,如属性都需用引号引起... 查看详情

json和对象之前的相互转换

1packagecom.jxjson.com;23importandroid.util.Log;45importorg.json.JSONArray;6importorg.json.JSONException;7importorg.json.JSONObject;89importjava.lang.reflect.Constructor;10importjava.lang.reflect.Fiel 查看详情

json对象与字符串之间的相互转换

<html><head><metaname="viewport"content="width=device-width"/><title>JSON对象与字符串之间的相互转换</title><scriptsrc="~/Js/jquery-1.8.0.js"></script><script>varuser 查看详情

个人技术总结

json字符串和对象的相互转换在数据传输过程中,json是以字符串的形式传递的,而JS操作的是JSON对象,这个技术实现的是json字符串和json对象之间的相互转换。使用方法json字符串转对象varstr1=‘"name":"usr1","passwor... 查看详情

fastjson对于json格式字符串json对象及javabean之间的相互转换

fastJson对于json格式字符串的解析主要用到了一下三个类:JSON:fastJson的解析器,用于JSON格式字符串与JSON对象及javaBean之间的转换。JSONObject:fastJson提供的json对象。JSONArray:fastJson提供json数组对象。我们可以把JSONObject当成一个Map... 查看详情

json的string字符串与java的list列表对象的相互转换

在前端:1.如果json是List对象转换的,可以直接遍历json,读取数据。2.如果是需要把前端的List对象转换为json传到后台,param是ajax的参数,那么转换如下所示:varjsonStr=JSON.stringify(list);varparam={};param.jsonStr=jsonStr;在后台:1.把String转... 查看详情