一、JSON的基本概念
- 加粗样式**JSON:JavaScript的对象表示法
- JSON是存储和交换文本信息的语法,类似于XM。它采用键值对的方式来组织,易于我们阅读和编写,同时也易于机器解析和生成
- JSON是独立于语言的,也就是说不管什么语言都可以解析json,只要按照json的规则来就行
二、JSON和XML比较
- json的长度和xml格式比起来是很短小的
- json读写的速度很快
- json可以使用JavaScript内建的方法直接进行解析,转换成JavaScript对象非常方便
三、JSON的语法规则
JSON的书写格式:名称-值 对
类似于名称:值得形式,名称和值都要写在各自得双引号中;例如:“name":"huangQian”
或者如下:首先是一个大括号,代表是一个JSON对象,里面是一个名称-值对,名称是$person,值是一个数组,数组里面又是几个对象,对象里面采用名称-值对,都是写在双引号中。
{
"$person":[
{"name":"pig","body":"fat","age":10},
{"name":"dog","body":"medium","age":20},
{"name":"snake","body":"slim","age":30}
]
}
四、JSON解析
- eval和JSON.parse()两中方法
- 在代码中使用eval是很危险的,特别使用它执行第三方的JSON数据(其中可能包含恶意代码)时,尽可能使用JSON.parse()方法解析字符串本身,该方法还可以捕捉JSON中的语法错误
使用两种方法如下:
<script>
var jsondata = '{"name":"张无忌","sex":"男"}';
var jsonobj_1 = eval('(' + jsondata + ')');
var jsonobj_2= JSON.parse(jsondata);
alert(jsonobj_1.name);//"张无忌"
alert(jsonobj_2.name);//"张无忌"
//若将jsondata改成下面这样,eval会将里面的函数执行,而JSON.parse会报错
var jsondata_B= '{"name":"张无忌","sex":alert("这是男")}';
var jsonobj_1 = eval('(' + jsondata_B + ')');
var jsonobj_2= JSON.parse(jsondata_B);
alert(jsonobj_1.name);//"张无忌" "这是男"
alert(jsonobj_2.name);//报错
</script>
所以说使用eval是非常危险的,除非里面的字符串是自己可控的
json格式化和校验工具:JSONLint,非常直接的检测出字符串是否符合json语法规则