03-Ajax传输json和XML

Ajax 传输 JSON

JSON 的语法

JSON(JavaScript Object Notation):是 ECMAScript 的子集。作用是进行数据的交换。语法更为简洁,网络传输、机器解析都更为迅速。

语法规则:

  • 数据在键值对中

  • 数据由逗号分隔

  • 花括号保存对象

  • 方括号保存数组

数据类型:

  • 数字(整数或浮点数)

  • 字符串(在双引号中)

  • 逻辑值(true 或 false)

  • 数组(在方括号中)

  • 对象(在花括号中)

  • null

示例:

  1. // 对象
  2. {
  3. "name":"fox",
  4. "age":"18",
  5. "sex":"true",
  6. "car":null
  7. }
  8. // 数组
  9. [
  10. {
  11. "name":"小小胡",
  12. "age":"1"
  13. },
  14. {
  15. "name":"小二胡",
  16. "age":"2"
  17. }
  18. ]

JavaScript 中:json 字符串 <—> js 对象

基本上,所有的语言都有将 json 字符串转化为该语言对象的语法。

比如在 js 中:

  • JSON.parse():将 JSON 字符串转化为 js 对象。例如:
  1. // 将 JSON 字符串格式化为 js 对象
  2. var jsObj = JSON.parse(ajax.responseText);
  • JSON.stringify():将 JS 对象转化为 JSON 字符串。例如:
  1. var Obj = {
  2. name: 'fox',
  3. age: 18,
  4. skill: '撩妹',
  5. };
  6. console.log(Obj);
  7. // 将 js 对象格式化为 JSON 字符串
  8. var jsonStr = JSON.stringify(Obj);

PHP 中:json 字符串 <—> js 对象

  • json_decode()方法:将json字符串转化为变量。

  • json_encode()方法:将变量转化为json字符串。

代码举例:

  1. <?php
  2. header("Content-Type:text/html;charset=utf-8");
  3. // json字符串
  4. $jsonStr = '{"name":"itcast","age":54,"skill":"歌神"}';
  5. // 字符串转化为 php对象
  6. print_r(json_decode($jsonStr));
  7. echo "<br>";
  8. // php数组
  9. $arrayName = array('name' =>'littleFox' ,'age' => 13 );
  10. // php对象 转化为 json字符串
  11. print_r(json_encode($arrayName));
  12. ?>

输出结果:

  1. stdClass Object ( [name] => itcast [age] => 54 [skill] => 歌神 )
  2. {"name":"littleFox","age":13}

ajax 请求解析 json(举例)

(1)Person.json:

  1. {
  2. "name": "小强",
  3. "skill": "砍树",
  4. "friend": "老板"
  5. }

(2)myJson.php:

  1. <?php
  2. // 读取json文件 并返回即可
  3. echo file_get_contents('info/Person.json');
  4. ?>

(3)getJson.html:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <title>Document</title>
  6. </head>
  7. <body>
  8. <h1>获取 json 数据</h1>
  9. <input type="button" value="获取json" id="btnJson" />
  10. </body>
  11. </html>
  12. <script type="text/javascript">
  13. // 获取的是一个 如果要获取多个
  14. // document.querySelectorAll(selector)
  15. document.querySelector('#btnJson').onclick = function () {
  16. var ajax = new XMLHttpRequest();
  17. ajax.open('get', 'myJson.php');
  18. ajax.send();
  19. ajax.onreadystatechange = function () {
  20. if (ajax.readyState == 4 && ajax.status == 200) {
  21. // json 字符串 是字符串 所以我们可以 通过 responseText获取
  22. console.log(ajax.responseText);
  23. // 转化为 js对象
  24. var jsObj = JSON.parse(ajax.responseText);
  25. console.log(jsObj);
  26. // 拼接ul s
  27. var str = '';
  28. str += '<ul>';
  29. str += '<li>' + jsObj.name + '</li>';
  30. str += '<li>' + jsObj.skill + '</li>';
  31. str += '<li>' + jsObj.friend + '</li>';
  32. str += '</ul>';
  33. // 设置到界面上
  34. document.body.innerHTML = str;
  35. }
  36. };
  37. };
  38. </script>

演示效果:

03-Ajax传输json和XML - 图1

Ajax 传输 XML

XML 语法

XML(Extensible Markup Language):可扩展标记语言。详细语法可以查看:#

1、XML 声明:

  1. <?xml version="1.0" encoding="UTF-8"?>

第一行的声明,指定了 XML 版本(1.0)以及使用的编码。

2、自定义标签:

XML 中没有默认的标签,所有的标签都是我们自己已定义的。例如:

  1. <fox></fox>
  2. <name></name>

XML 中没有单标签,都是双标签。

3、根节点:

XML 中必须要有一个根节点,所有的子节点都放置在根节点下。例如:

  1. <root1>
  2. <name></name>
  3. </root1>

XML 解析

因为 XML 就是标签,所以我们可以直接用解析 Dom 元素的方法解析 XML。

解析过程:

(1)html 部分:(包含 xml )

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <title>Document</title>
  6. </head>
  7. <body>
  8. <person id="personXML">
  9. <name>fox</name>
  10. <age>18</age>
  11. <skill>小花花</skill>
  12. </person>
  13. </body>
  14. </html>

(2)解析 xml:

  1. <script type="text/javascript">
  2. var xmlObj = document.getElementById('personXML');
  3. var name = xmlObj.getElementsByTagName('name')[0].innerHTML;
  4. console.log(name);
  5. </script>

ajax 请求解析 xml(举例)

(1)get_xml.php:(里面包含了 xml 文件)

  1. <?php
  2. // 设置 返回的为 xml
  3. header('content-type:text/xml; charset= utf-8');
  4. // 读取xml文件 并返回
  5. echo file_get_contents('info/star.xml');
  6. ?>

上方代码解释:

  • php 自带了 读取 xml 文件的方法。

  • 在 php 中,如果要使用 xml 传输数据,则需要使用 header()设置返回的内容为 xml。

(2)get_xml.html:(Ajax 请求,获取并解析 xml)

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <title>Document</title>
  6. </head>
  7. <body>
  8. <input type="button" value="获取XMl数据" id="getXML" />
  9. </body>
  10. </html>
  11. <script type="text/javascript">
  12. document.querySelector('#getXML').onclick = function () {
  13. var ajax = new XMLHttpRequest();
  14. ajax.open('get', 'get_XMl.php');
  15. ajax.send();
  16. ajax.onreadystatechange = function () {
  17. if (ajax.readyState == 4 && ajax.status == 200) {
  18. // 如果 返回的是 xml文件
  19. console.log(ajax.responseText);
  20. // 异步 对象中 有另外一个属性 用来专门获取 xml
  21. // xml对象 在浏览器段 就是一个 document对象
  22. // 解析时 可以直接使用 querySelector 或者 getElementById等等 document对象 有的语法
  23. console.log(ajax.responseXML);
  24. console.log(ajax.responseXML.querySelector('kuzi').innerHTML);
  25. // 下面这个 页面文档对象 如果要获取某个标签
  26. console.log(window.document);
  27. }
  28. };
  29. };
  30. </script>