JSON对象标记对XML的解析是基于DOM的,对HTML的DOM熟悉的话,解析XML就没什么困难了。注意:在Firefox中,解析器不会忽略空格,所以元素间的空格,FF一样会认为是一个节点。
一、JSON对象标记(JavaScript Object Notation),是一种以JS声明对象的方式组合的一串字符串。JS可以按以下方式定义对象:
- var obj =
- {
- id: 2,
- name: 'n'
- };
这样就定义了对象 obj, 它有两个公共属性id和name,可以用 obj.id 的方式直接访问其属性值。从服务器获取数据时往往不止一个对象,这就需要用到对象数组,JS中对象数组可以用 [] 来定义,如下:
- var objs = [{ id: 1, name: 'n_1' }, { id: 2, name: 'n_2'}];
- alert(objs[0].id);
这样就定义了对象数组 objs, 它包含两个对象,可以用索引来访问,如 objs[0] 将引用到***个对象。到这里你或许已经想到服务器返回的字符串格式是怎样的,但字符串毕竟是字符串,我们需要将其转换为可以利用JS操作的变量。这就用到 eval 函数,请看下例:
- var objs = eval("[{ id: 1, name: 'n_1' }, { id: 2, name: 'n_2'}]");
- lert(objs[0].id); // return 1
JSON对象标记在Default.aspx 文件中添加测试脚本:
- <script type="text/javascript">
- function getJson() {
- // 在IE7下测试通过,IE6下必须创建 new ActiveXObject("MSXML2.XMLHTTP.6.0")
- var request = new XMLHttpRequest();
- request.open('GET', 'GetJson.ashx');
- request.onreadystatechange = function() {
- if (request.readyState == 4 && request.status == 200) {
- var objs = eval(request.responseText);
- alert(objs.length); // 2
- alert(objs[0].id); // 1
- alert(objs[1].name);// 'n_2'
- }
- }
- request.send(null);
- }
- </script>
【编辑推荐】