JSON JSON字符串和JSON对象的区别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JSON JSON字符串和JSON对象的区别相关的知识,希望对你有一定的参考价值。

参考技术A 最近在学习Vue.js,里面有个存储、读取本地缓存的功能,不停地用 JSON.parse() ,和 JSON.stringify() 来转换JSON字符串和JSON对象。自己有点晕,不明白两者的区别,看起来感觉是一样的,也不知道为什么一定要转换才能用,后来去网上查了些资料,总结一下。

JSON对象是直接可以使用jQuery操作的格式。
JSON字符串仅仅只是一个字符串,一个整体,不截取的话没办法读取其中存储的数据,不能直接使用。除非alert()它。
JSON对象:

JSON字符串:

注:上面几个转换方法,除了eval()函数是js自带的之外,其他的几个方法都来自json.js包。现在JSON.stringify()和JSON.parse()两个方法都注入到了JavaScript的内建对象里面,前者变成了Object.toJSONstring(),后者变成了String.parseJSON()。

json 字符串指的就是 json 本身,由于 JavaScript 是弱类型语言,所以没有办法直接传递对象或是数组,所以提出了 json 格式的字符串,用于数据传递;
ajax 中,我们自己拼接的是一个JSON对象,因为它是无数据类型的,所以 JS 根据其格式默认其是对象,要是往后台发,要先把它转换成 JSON字符 。
从 ajax 的服务器 发过来的,一定是字符串,你想要把它解析,很简单,把它先变成JSON对象才行。

在数据传输过程中, json 是以文本,即字符串的形式传递的,而 JS 操作的是 JSON对象 ,所以 JSON对象 和 JSON字符串 之间的相互转换是关键。

对象是一个类的实例,可以调用类里面封装好的方法,但是字符串所能调用的方法就是字符串本身具备的那些指定的方法。

json对象和json字符串有啥区别啊

json对象可以通过javascript存取属性!json对象装成json字符串经常用于前后台传输数据!


如果你在前台使用,那么Json对象可以通过xx.name来调用,如果是字符串,那么就是字符串了


ajax中,我们自己拼接的是一个JSON对象,以为它是无数据类型的,所以JS根据其格式默认其实对象,

你要是往后台发,要先把它装换成JSON字符。

 

从ajax的服务器发过的,一定是字符串,你想要把它解析,很简单,把它先变成JSON对象才行。

 

太厉害了。

 

数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键。例如:
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);

 

以上是关于JSON JSON字符串和JSON对象的区别的主要内容,如果未能解决你的问题,请参考以下文章

JSON字符串与JSON对象的区别

JSON JSON字符串和JSON对象的区别

json对象和json字符串有啥区别啊

JSON字符串与JSON对象的区别及转换

node json.parse和querystring.parse的区别

JSON和JavaScript对象