XML知识点总结

1、XML 简介

XML是  :可扩展标志性语言( extendsible Markup Language) xml是w3c(万维网联盟,WEB技术最权威的国际中立性的技术标准机构)组织发布的技术

    xml 有两个版本 1.0 1.1,这里需要注意的是我们使用的是使用1.0 版本(1.1不能向下兼容)。

 先来解释一下这个可扩展标志性语言是什么意思:

       标记型语言 :html是标记型语言、使用标签操作。
       可扩展:html里的标签都是固定的,每个标签都有特定的含义, XML 不是固定的,标签可以自己定义, 比如可以写中文的标签<人></人> <person></person>
 既然我们要学习XML,就需要知道xml 的用途
        ** HTML 用以显示数据,XML也可以显示数据, 但不是主要功能
        ** XML 主要功能是 存储数据
   
2、XML的应用

在实际开发中我们主要把XML实现如下的功能:

           不同系统之间传输数据,数据结构清晰,利于维护,用来表示生活中有关系的数据, 经常用在配置文件,比如现在连接数据库,肯定要知道数据库IP地址用户名密码等,直接    写程序中不好维护, 单独放在一个配置文件中利于维护


3、XML的语法

要学习会使用XML就必须得会下面几点。    

(1) xml的文档声明

   * 创建一个文件 后缀名是 .xml
   * 如果写xml ,第一步必须有一个文档声明(表示这是一个xml文档)
        
 <?xml version="1.0" encoding="utf-8"?>
    *** 文档声明必须是文档的第一行,并且是第一列

        关于头文件属性的解释:
             - version:xml的版本 1.0(文中使用的版本) 1.1
             - encoding: xml编码 gbk utf-8 iso8859-1(不包含中文) 等等 ,这个编码指定打开该文件时读取文件内容的编码,不是保存的编码

            - standalone:是否需要依赖其他文件yes/no


        * xml中文乱码的问题
            编辑好xml文件后->默认按系统编码保存,通常是gbk -> 然后打开xml的时候,打开程序(例如IE)根据xml文件的encoding编码去解码
            此时如果encoding 指定的编码跟保存时编码不一致,就会出问题,解决的办法是让 保存时和打开时的编码都一致

(2) 定义元素(标签)

        ** 标签定义要符合如下的规定:
                      标签定义有开始必须要有结束:<person></person>
                      标签没有内容的可以在标签内结束<person value="as"/>
                      标签可以嵌套,但必须合理,例如下面这个例子:
                            合理:<a><b></b></a>

                            不合理: <a><b></a></b>

         ** xml标签命名规则
            (1) xml中区分大小写, <i>和<I>是两个不同标签
            (2) 标签名称不能以数字或下划线开头
            (3) 不能以xml 以及xml大小写开头,这是不允许的, <xmla> <Xmlb> <XMLx> 这些都是不允许
            (4) 标签名称不能包含空格和冒号 如 <a b> <a:b>都不对

         标签的定义还得注意以下几个:

        ** 一个xml中, 只能有一个根标签,其他标签都是根标签下的标签

        ** 在xml中把换行和空格都当成内容来解析


         下面两段代码含义不一样
    
          <a>1111</a>
              <a>
                 1111
              </a>
(3) 定义属性
       上面已经说到xml是标记型文档,所以和HTML一样可以有属性,接下来我们就说如何定义属性:
     
<person id="aaa" />

        ** 属性定义的要求
            (1) 一个标签可以有多个属性,比如:<person id="aaa" xx="aaa"></person>
            (2) 属性名称不能相同
            (3) 属性名和属性值之间使用= ,属性值使用引号包起来(可以使单引号,也可以双引号)

            (4) 属性名称规范和元素规范一致


(4) 注释

        * XML注释的写法: <!--xml的注释-->
        ** 注意的地方
            *** 注释不能嵌套, <!--<!---->-->这个是错误的

            *** 注释不能放在文档的第一行,因为第一行是文档声明


(5) 特殊字符
        ** 特殊字符和html的特殊字符一样处理,这里也不过多说明了。

(6) CDATA 区
        这个的功能是可以解决多个字符需要转义的操作, 把这些内容放到CDATA区就不需要一个个转义了,这个也很少用到。
        ** 写法<![CDATA[内容]]>,如:<![CDATA[a<b , a>b]]>

        ** CDATA 区会把特殊字符当文本内容,而不是标签


(7) PI指令
       这个指令的功能是 可以在xml中设置样式
        * 写法: <?xml-styleheet type="text/css" href="css路径"?>
        注意: 只对英文标签名称起作用
    
(8) xml的约束
        对元素严格规定,比如规定一个<persons>下面直接子节点只能是<person> 而不能是<猫>

        *约束技术 DTD 和schema,



4、DTD 快速入门 查看文档
DTD(文档类型定义)的作用是定义 XML 文档的合法构建模块。它使用一系列的合法元素来定义文档结构。这里我也不多说了,这个可以看文档的,可以看文档或者百度百科学习。
5、DTD的三种引入方式
     (1) 引入外部的dtd文件

        <!DOCTYPE 根元素名称 SYSTEM "dtd文件路径">


    (2) 使用内部的DTD文件

        <!DOCTYPE 根元素名称 [
            <!ELEMENT person(name,age)>
            <!ELEMENT name(#PCDATA)> //表示在<name>和</name>标签之间可以插入字符或者子标签。
            <!ELEMENT age(#PCDATA)>
        ]>

        #PCDATA (Parsed Character Data 被解析的字符数据 任何)


    (3) 使用外部的dtd文件(网络上的dtd文件)
        <!DOCTYPE struts PUBLIC
            "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

            "http://struts.apache.org/dtds/struts-2.0.dtd">


6、使用DTD定义元素

     DTD 语法:<!ELEMENT 元素名 约束>


      (1)简单元素没有子元素的元素

        简单元素结构如下     

       <!ELEMENT name (#PCDATA)>

      (#PCDATA) :表示在<name>和</name>标签之间可以插入字符或者子标签
      EMPTY:元素为空(没有内容)

       ANY : 任意


    (2)复杂元素

      复杂元素结构如下

        <!ELEMENT person (name,age,sex)> //注意空格

        <!ELEMENT 元素名称 (子元素)>
       用下列符号 表示子元素出现的次数:
            +:表示一次或多次
            ?:表示零次或一次
            *:表示零次或多次

        子元素之间用逗号隔开 表示元素出现的顺序,如:<!ELEMENT person (name+,age?,sex*)>

        子元素与出现次数之间用|隔开.表示元素只能出现其中的任意一个,如:<!ELEMENT person (name+|age?|sex*)>

7、使用DTD来定义属性

   定义属性语法: <!ATTLIST 元素名称  属性名称 属性类型 属性的约束 >

 

   而其中属性类型有三种

        - CDATA :字符串,如: <!ATTLIST person id1 CDATA #REQUIRED>

        - 枚举 :表示只在一定范围内出现的值,而且每次出现其中一个,如: <!ATTLIST person id1 (AA|BB|CC)  #REQUIRED>

       - 值只能是字母或者下划线开头,如:  <!ATTLIST person id1 ID  #REQUIRED>

    其中的属性的约束有三种
     -  #REQUIRE D 必须要存在
     - #FIXED :表示一个固定值 #FIXED "AAA", 属性值必须 是设置的固定值
     - 直接值 默认值
            不写属性 ,使用直接值
            写了属性,使用设置的那个值
           <!ATTLIST person id1 CDATA  "AAA">

8、实体的定义
  实体定义语法语法 :<!ENTITY 实体名称 "实体值">
    使用实体 &实体名称
   注意:定义的实体需要写在内部DTD中,如果写在外部DTD,某些浏览器下可能得不到

9、XML的解析(重要)
      我们都知道js使用DOM  -- document object model 来解析HTML
        - document 、element对象、属性对象、文本对象、Node节点对象
     xml 解析技术: dom 和 sax
        (1)dom解析
                根据xml的层级结构在内存中分配一个树形结构,把xml的标签,属性,文本都封装为对象
                缺点,如果文件过大会造成内存溢出
               优点 , 方便实现增删改操作
       (2)sax 解析
               采用事件驱动,边读边解析,从上到下,一行一行的解析
               缺点 :不能实现增删改操作
               优点 :如果文件过大,不会造成内存溢出,方便实现查询操作
    常用的解析器有 Dom4j,提供dom和sax两种方式的解析器
     

10、schema约束     为替代DTD存在
    dtd语法 :<!ELEMENT 元素名称 约束>
  schema符合XML语法,是XML语句, 一个xml中可以有多个schema,多个schema用命名空间区分(类似JAVA的包名), dtd里有PCDATA类型,但是在schema中可以支持更多数据类型, 比如年龄 只能是整数 ,在schema中可以直接定义一个整型类型, schema语法更加复杂, 目前还不能代替dtd

   schema的快速入门
       创建一个schema文件 后缀名是.xsd, 根节点<schema>
        
        在schema文件里面
           属性xmlns = "http://www.w3.org/2001/XMLSchema"; //表示你创建的是一个约束文档
           属性tagetNamespace = "http://www.chj.com/2014"; //命名空间,如果要使用约束文件,直接通过这个地址引入
            //当设置为unqualified时全局元素(可作为根元素)必须添加命名空间前缀,非全局元素不必添加前缀。
           属性elementFormDefault="qualified" // 当设置为qualified时,所有的元素都必须添加前缀。
        
        步骤
            (1)、看xml中有多少个元素  <ELEMENT>
            (2)、看简单元素和复杂元素
            
          <element name="person">
                    <complextype> //如果是复杂元素
                        <sequence>
                            <element name="name" type="string"></element>
                            <element name="age" type="intger"></element>
                        </sequence>
                    </cpmplextype>
                </element>


            (3)、在被约束的文件中引入约束文件
                  <person xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" //instance表示这是一个被约束的文件,两个xmlns所以这里要取个xsi作为前缀区分
                    xmlns="http://www.luowg.com/2014"//是约束文件里的 targetNamespace

                    xsi:schemaLocation="http://www.luowg.com/2014 xx.xsd">//targetNamespace 空格 约束文件的路径


你可能感兴趣的:(编程,xml,技术,基础,经验)