JSON学习(一):json数据格式

我们先来看下w3cschool对json的定义:

JSON:JavaScript 对象表示法(JavaScript Object Notation)。

JSON 是存储和交换文本信息的语法。类似 XML。

JSON 比 XML 更小、更快,更易解析。

 使用中,json有以下三种结构:

对象:{"name":"Michael","age":24}

数组:比如:[{"name":"Michael","age":24},{"name":"Tom","age":25}]

值:{"name":"Michael", "birthday":{"month":8,"day":26}},类似于对象嵌套对象.

 很多人疑惑{}和[]形式的区别。看到一段很经典的总结:大括号{}用来描述一组“不同类型的无序键值对集合”(每个键值对可以理解为OOP的属性描述),方括号[]用来描述一组“相同类型的有序数据集合”(可对应OOP的数组)

上面的例子中,键都是字符串形式,值可以取任意类型。对于var p1={name:"Michael",age:24},我们称为对象自面量。两者是不同的,例子后面会讲到。

 访问json数据的两种方法:

//例子
var  obj={name:"Michael",age:24};

obj.name;//方式1,和java语言中访问对象的属性是一样的。

alert(obj["name"]) //方式2,和js中数组的访问方式是一样的。

 Json数据字符串化(序列化):

          Json数据是跨平台的,在网络数据传输流程中,json是以文本,即字符串的形式传递的,各种语言对字符串的处理比较统一。而在JS是 对象的形式。

JSON.stringify()将JSON对象转为JSON字符串(序列化);

JSON.parse()将JSON字符串转为JSON对象(反序列化)

  例子: 

复制代码

<script>

 var  obj={"name":"Michael","age":24};

 var  obj1=JSON.stringify(obj);//注意:json全大写

 

 

 alert(obj);//弹出Object类型;说明是对象

 alert(obj.name);//弹出属性值

 alert(obj1);//弹出转化为字符后的;

 

 var  obj2 = JSON.parse(obj1);

 alert(obj2)//转换后,弹出Object类型;说明已经转化成对象;

</script>

复制代码

 对象字面量的例子:

复制代码
<script>

 var  obj={name:"Michael",age:24};

 

 alert(obj);//弹出Object类型;说明是对象

 alert(obj["name"])//alert(obj.name),但是obj[name]不行

 

 var  obj1=JSON.stringify(obj);//注意:json全大写

 alert(obj1);//弹出转化为字符后的;{"name":"Michael","address":24};

 

</script>
复制代码

 这个例子看出,对象字面量的使用方法跟json完全一样。个人以为,可以理解为已经转化成json了。

猜你喜欢

转载自blog.csdn.net/qq_27954241/article/details/80773770