AJAX中的XML和JSON

XML简介

  1. HTML/XHTML/DHTML/XML
    HTML: 网页文档
    XHTML:更严格的网页文档
    DHTML:BOM|DOM
    XML: 可扩展的标记语言,可用于配置文件|数据格式

  2. XML的文件为.xml

  3. XML的定义方式与HTML非常相似

    HTML的元素都是预定义好的
    XML允许自定义元素

  4. XML版本

    1.0版本 1.1版本,几乎没人使用

  5. XML作用

    作为数据格式-存储数据的地方

  6. XML语法

    1)声明

    <?xml version="1.0" encoding="utf-8" ?>
    
    version-设置XML文件的版本
    encoding-设置XML文件的编码
    
    声明必须出现在1行1列上
    

    2)定义元素

    根元素,必须是双标签,只能定义一个
    
    定义元素,元素名可以自定义,既可以双标签也可以是单标签
    
DOM解析XML字符串
  1. 创建DOM解析XML的解析器,解析器解析XML字符串

    IE浏览器
    var parser = new ActiveXObject("Microsoft.XMLDOM");

    parser.async = false;
      
    xmlDoc = parser.loadXML(xmlFile);
    

    其他浏览器
    var parser = new DOMParser();

    var xmlDoc = parser.parseFromString(xmlFile,"application/xml");
    
  2. 解析XML元素与解析HTML元素一致

    获取元素最常用的是getElementsByTagName很少使用ById和ByName

PS:

 浏览器不允许读取外部的XML文件
 浏览器解析符合XML格式的字符串

Ajax的XML

1.请求的数据格式-XML

  1)客户端如何构建XML格式的数据

    构建的数据类型 - 字符串类型
    字符串的内容要符合XML格式的语法要求

  2)服务器端如何接受符合XML格式的数据

     接收到的客户端的请求数据 - 字符串类型,php集成了DOM的相关内容

       DOMDocument
       DOMElement
       DOMNode

2.响应的数据格式-XML

  1)服务器端如何构建符合XML格式的数据

    设置服务器端的响应头Content-Type值为text/xml

      header("Content-Type:text/xml");

    构建符合XML格式的数据内容

       手动方式构建字符串内容

       DOMDocument对象的方法
         loadXML(符合XML格式的字符串)
         saveXML()方式进行响应

  2)客户端如何接受XML格式的数据

      使用XMLHttpRequest对象的responseXML属性接收

      接收到的就是XML DOM对象(不需要进行解析)

JSON简介

  1. JSON - javascript object notation(JS原生支持)

  2. json数据格式源于js

  3. 特点:
    易于程序员阅读和编写
    易于计算机解析和生成
    json是目前网络上使用最广泛的数据格式之一

  4. JSON的结构

    Array和Object

    支持的数据类型

    字符串、数值、布尔值、对象、数组、null

ajax中的json格式
  1. 请求格式为json

    客户端向服务器端发送请求为json格式的数据

    构建符合JSON格式的字符串
    定义字符串时,保证里面使用双引号,外面使用单引号
    

    服务器端接受json格式的数据

    使用json_decode()函数进行解析
    json_decode($json,true);ture代表是否转换为数组
    
  2. 响应格式为json

    服务器端向客户发送响应为json格式的数据

    手工方式构建json格式的字符串
    
    使用json_encode()函数将php变量(数组),转换成复合json格式的字符串
    

    客户端接受json格式的数据

     使用XMLHttpRequest对象的responseText属性接受
    
     然后使用eval函数进行转换,如果使用()包裹,eval函数强制转换为js代码
     var json = eval("("+data+")");
    

HTML(文本)、XML格式、JSON格式的优缺点

HTML: 简单,但解析复杂
XML:  构建、解析复杂
JSON: 轻量级
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • XML XML语法 1)声明 <?xml version="1.0" encoding="utf-8" ?>...
    不住海边也喜欢浪阅读 335评论 0 1
  • JSON JSON和XML都是需要解析的 JSON是一种轻量级的数据格式,一般用于数据交互服务器返回给客户端的数据...
    JonesCxy阅读 1,920评论 2 10
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,256评论 19 139
  • ajax中的xml 1.请求的数据格式-XML 2.响应的数据格式-XML ajax中的json 一、json 1...
    我是渐渐呀阅读 395评论 0 0
  • -1- 宾朗正在健身房里不停的擂打着沙袋,汗水已经将他的背心濡湿。见到我后,愈加的“嘭嘭”作响,以示对某种愤怒的宣...
    麦动文阅读 609评论 19 59