JSON字符串转换为JSON对象,JSON对象转化为JSON字符串
发布日期:2022-01-31 02:37:37 浏览次数:29 分类:技术文章

本文共 1800 字,大约阅读时间需要 6 分钟。

例如:JSON字符串:

var str1 = '{ "name": "cxh", "sex": "man" }'; 
JSON对象:
var str2 = { "name": "cxh", "sex": "man" };

一、JSON字符串转换为JSON对象

要使用上面的str1,必须使用下面的方法先转化为JSON对象:

//由JSON字符串转换为JSON对象

var obj = eval('(' + str + ')');

或者

var obj = str.parseJSON(); //由JSON字符串转换为JSON对象

或者

var obj = JSON.parse(str); //由JSON字符串转换为JSON对象

然后,就可以这样读取:

Alert(obj.name);

Alert(obj.sex);

特别注意:如果obj本来就是一个JSON对象,那么使用eval()函数转换后(哪怕是多次转换)还是JSON对象,但是使用parseJSON()函数处理后会有问题(抛出语法异常)。

二、可以使用toJSONString()或者全局方法JSON.stringify()将JSON对象转化为JSON字符串。

例如:

var last=obj.toJSONString(); //将JSON对象转化为JSON字符

或者

var last=JSON.stringify(obj); //将JSON对象转化为JSON字符

alert(last);

注意:

上面的几个方法中,除了eval()函数是js自带的之外,其他的几个方法都来自json.js包。新版本的 JSON 修改了 API,将 JSON.stringify() 和 JSON.parse() 两个方法都注入到了 Javascript 的内建对象里面,前者变成了 Object.toJSONString(),而后者变成了 String.parseJSON()。如果提示找不到toJSONString()和parseJSON()方法,则说明您的json包版本太低。

---------------------------------------------------------------------------------------------------------------------------------------

本人在用JSON.parse把字符串转化为json对象时,一直报错VM356:1 Uncaught SyntaxError: Unexpected token i in JSON at position 1,很费解,var str1 = "{'name':'cxh','sex':' man'}";一直认为这个字符串没有任何问题,最终发现,使用parse这个方法,要求很严格,必须是var str1 = '{ "name":"cxh","sex":" man" }';就是json的k和value必须都用双引号包起来;

谨记json格式问题k和value都加双引号,单引号也不可以

var str1 = '{ "name":"cxh","sex":" man" }';

console.log(JSON.parse(str1));
console.log(JSON.parse(str1)["name"]);

---------------------------------------------------------------------------------------------------------

默认情况下,jQuery 将自动根据 HTTP 包 MIME 信息返回 responseXML 或 responseText,并作为参数。因此你取得的data是一个字符串,如需使用就需要用str.parseJSON()进行转换,这个方法是将字符串转换为Json对象。 你如果想直接使用,可以在请求参数里指定返回值类型: $.ajax({
url: "/i/ajax/get_cp_data", dataType: 'json', success: function(data){
alert(data.uid); } });

转载地址:https://blog.csdn.net/m0_37968109/article/details/78455790 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:linux远程服务连接不上,或连接超时解决方法
下一篇:HTML5本地存储-localStorage如何实现定时存储

发表评论

最新留言

路过按个爪印,很不错,赞一个!
[***.219.124.196]2024年04月20日 03时48分18秒