欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JSON与JS对象的区别与对比

程序员文章站 2023-12-04 09:02:28
json是什么?(json和javascript对象有什么区别?)如何把js对象转化为json字符串,又如何把json字符串转化为javascript对象? json (...

json是什么?(json和javascript对象有什么区别?)如何把js对象转化为json字符串,又如何把json字符串转化为javascript对象?

json (javascript object notation)一种简单的数据格式,比xml更轻巧。 json 是 javascript 原生格式,这意味着在javascript 中处理 json 数据不需要任何特殊的 api 或工具包。json的规则很简单: 对象是一个无序的“名称/值”对集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“名称/值”对之间使用“,”(逗号)分隔。

它是一种严格的js对象的格式,json的属性名必须有双引号,如果值是字符串,也必须是双引号;

json只是一种数据格式(或者叫数据形式);

<script>
var obj2={};//这只是js对象
var obj3={width:100,height:200};/*这跟json就更不沾边了,只是js的 对象 */
var obj4={'width':100,'height':200};/*这跟json就更不沾边了,只是js的对象 */
var obj5={"width":100,"height":200,"name":"rose"}; /*我们可以把这个称做:json格式的javascript对象 */
var str1='{"width":100,"height":200,"name":"rose"}';/*我们可以把这个称做:json格式的字符串 */
var a=[
 {"width":100,"height":200,"name":"rose"},
 {"width":100,"height":200,"name":"rose"},
 {"width":100,"height":200,"name":"rose"},
 ];
 /*这个叫json格式的数组,是json的稍复杂一点的形式 */
var str2='['+
 '{"width":100,"height":200,"name":"rose"},'+
 '{"width":100,"height":200,"name":"rose"},'+
 '{"width":100,"height":200,"name":"rose"},'+
 ']' ;
 /* 这个叫稍复杂一点的json格式的字符串 */ 
</script>

json和js对象区别对比表

区别

json

javascript对象

含义

仅仅是一种数据格式

表示类的实例

传输

可以跨平台数据传输,速度快

不能传输

表现

1,键值对方式,键必须加引号

2,值不能是方法函数,不能是undefined/nan

1,键值对方式,键不加引号

2,值可以是函数、对象、字符串、数字、boolean 等

相互转换

json转化为js对象:

1,json.parse(jsonstring);
(不兼容ie7)

2,jsobj=eval("("+jsonstring+")");

(兼容所有浏览器,但不安全,会执行json里面的表达式?)

js对象转换为json:

json.stringify(jsobj);(不兼容ie7)

其他

调用json官网的js,实现parse 和 stringify 在各个浏览器的兼容:

https://github.com/douglascrockford/json-js/blob/master/json2.js

总而言之你可以理解为json是js下的一种数据格式,他从属于js,并且在处理json数据时可直接使用js内置api