码迷,mamicode.com
首页 > 其他好文 > 详细

XML

时间:2016-09-17 16:30:17      阅读:133      评论:0      收藏:0      [点我收藏+]

标签:

  1 XML
  2   * extensible Markup Languae :可扩展标记型语言
  3     ** 标记型语言:html是标记型语言
  4         - 也是使用标签来操作
  5     ** 可扩展:
  6         - html里面的标签是固定的,每个标签都有特定的含义<h1><br/><hr/>
  7         - 标签可以自定义,可以写中文的标签<person></persn> <猫></猫>
  8     * xml用途
  9         ** html适用于显示数据,xml也可以显示数据(不是主要功能)
 10         ** xml只要功能,为了存储数据
 11 
 12     * xml是w3c组织发布的技术
 13     * xml有两个版本:1.0    1.1 
 14      -使用1.0版本:(1.1版本不能向下兼容)。
 15 * xml的应用
 16     * 不同的系统之间传输
 17         ** qq之间数据传输
 18     * 用来表示生活中有关系的数据
 19     * 经常用在来配置文件
 20 
 21 * xml语法
 22     (1)xml的文档声明
 23         * 创建文件,后缀为.xml
 24         * 如果写xml 第一步必须要有一个文档声明(写了文档声明之后,表示写xml文件)
 25             ** <?xml version="1.0" encoding="GBK"?>
 26             ** 文档声明必须写 第一行 第一列
 27         * 属性
 28             - version: xml的版本1.0(使用1.0)
 29             - encoding:xml编码 gbk utf-8 iso8859-1(不包含中文)
 30             - standalone: 是否需要依赖其他文件 yes/no
 31             - xml的中文乱码 计算机默认保存时gbk 自己定义时utf-8就会乱码 应该在保存时改掉计算机默认为设置的编码
 32     (2)定义元素(标签)
 33     (3)定义属性
 34     (4)特殊字符
 35     (5)注释
 36     (6)CDATA区
 37     (7)PI指令
 38 5*xml的元素定义:
 39     ** 标签定义:
 40         ** 有开始有结束<person></person>
 41         ** 可以再内部结束<person />
 42         ** 标签可以嵌套,必须要合理:
 43             ** 合理嵌套<bb><aa></aa></bb>
 44         ** 只能有一个根标签,其他的都是子标签
 45         ** 空格和内容都会解析:不能写空格
 46         ** xml标签可以使中文
 47 
 48         ** xml中标签的名称规则
 49             (1)xml代码区分大小写
 50             (2)xml的标签不能以xml开头
 51             (3)xml不能以数字下划线开头
 52             (4)xml不能包含空格和冒号
 53 
 54 * xml照片那个特殊字符
 55     ** 小于号:&lt
 56     ** 大于号:&gt
 57     ** 双引号:&quot
 58     ** 单引号:&apos
 59     ** & :&amp
 60 
 61 * CDATA区:
 62     ** 可以解决多个字符都需要专一的操作 
 63     ** 把这些内容放在CDATA中不需要转义;
 64     ** 写法:就是把特殊字符当成文本内容显示出来
 65         ** <![CDATA][内容]]>
 66 
 67 * PI指令(处理指令) 只对应为标签起做用
 68     ** 可以再xml中设置效果
 69     ** 导入css写法: <?xml-stylesheet type="text/css" href="路径" ?>
 70 
 71 * xml约束:
 72     **  一个dad约束 一个schema约束
 73         *** dtd快速入门
 74             * 创建文件 后缀: .dtd
 75             * 步骤;
 76                * 有多少元素 就在dtd中创建几个<!ELEMENT>
 77                * 判断元素是简单元素还是复杂元素
 78                 - 简单元素:没有子元素
 79                     <!ELEMENT  元素名称(#PCDATA) >
 80                 - 复杂元素:有子元素的元素 
 81                     <!ELEMENT  元素名称(子元素名称) >
 82              * 将dtd引入xml中方法
 83                 * <!DOCTYPE 元素名称 SYSTEM "dtd路径">
 84     ** dad三种引入方式;
 85         (1) 引入外部dtd文件
 86             <!DOCTYPE 元素名称 SYSTEM "路径">
 87         (2) 内不直接写;
 88             <!DOCTYPE 元素名称 [
 89                 - 简单元素:没有子元素
 90                     <!ELEMENT  元素名称(#PCDATA) >
 91                 - 复杂元素:有子元素的元素 
 92                     <!ELEMENT  元素名称(子元素名称) >
 93     
 94             ]>
 95         (3) 使用外部dtd文件(网络上的)
 96             <!DOCTYPE 根元素 PUBLIC "DTD名称" "dtd文档路径URL">
 97             在后面学到的 框架中 struts2中学到 使用配置文件用
 98 * 使用dtd定义元素
 99     *简单元素:没有子元素的元素
100         <!ELEMENT name (#PCDATA)>
101         *** (#PCDATA);约束那么是字符串类型
102         *** EMTY: 元素为空 (没有内容)
103         *** ANY:任意
104     * 复杂元素:
105     <!ELEMENT person (name,age)>
106         -子元素只能出现一次
107         ** 表示元素出现的次数;
108             +: 表示一次或多次
109             ?: 表示零次或一次
110             *: 表示出现任意次数 (有没有都行)
111         **子元素之间用 , 号隔开,表示元素出现的顺序.
112         **子元素之间用 | 号隔开,表示元素出现的顺序.
113 
114 * 使用dtd定义属性
115     * 语法: <ATTLIST 元素名称
116             属性名称 属性类型 属性的约束
117         >
118     * 属性类型
119         - CDATA :字符串
120             - <!ATTLIST birthday
121                 ID1 CDATA #REQUIRED
122             >
123         - 枚举: 表示只能在一定的范围内出现值,但是只能每次出现其中一个.
124             ** 红绿灯效果
125             ** (aa|bb|cc)
126             - <!ATTLIST age
127                 ID2 (AA|BB|CC) #REQUIRED
128             >
129         ID :值只能是字母或者下划线开头
130     * 属性的约束  <!ELEMENT  ><age  ID="DDD">20</age>
131         - #REQUIRED ;表示必须有
132         - #IMPLIED;表示可有可无
133         - #FIXED :表示一个固定值, #FIXED "AAA"
134             - 属性的值必须是设置的这个固定值
135             - <!ATTLIST sex 
136                 ID4 CDATA #FIXED "ABC"
137             >
138         - 直接值:
139             * 不写属性,使用直接值
140             * 写了属性,使用设置那个值
141                 -<!ATTLIST school
142                     ID5 CDATA "DDD"
143                 >
144     * 定义实体:
145         * 语法: <!ENTITY 实体名称 "实体的值">
146         ** 定义实体<!ENTITY TEST "HAHAHA">
147         ** 使用实体 &实体名称; 比如: &TEXT;
148 
149         ** 特别注意:
150             * 定义的实体需要写在内部的dtd里面
151     
152     * schema约束:
153         ** dtd语法: <!ELEMENT 元素名称 约束>
154         ** schema符合xml的语法,xml语句:
155         ** 一个xml中可以有多个schema,多个schema使用名称空间来区分(类似于java中的包)
156         ** dtd里面有PCDATA类型.但是schema里面可以支持更多的数据类型 
157             *** 比如 年龄 只能是整数 在schema可以直接定义一个整数类型
158             **语法更加复杂,所以schema目前不能替换dtd.
159     * schema的快速入门
160         *后缀名为 .xsd
161         * 创建一个schema文件
162             ** 根节点就是<schema>
163         * 在schema文件中
164             ** 属性 xmlns="http://www.w3.org/2001/XMLSchema"
165                 - 表示当前xml问价是一个约束文件166             ** targetNmaespace="http://www.itcast/cn/20151111"
167                 - 使用schema约束文件,直接通过这个地址引入约束文件
168             ** elementFormDefault="qualified"
169         * 步骤:
170             (1) 看xml中有多少元素
171                 <element>
172             (2) 看简单元素和复杂元素
173                 - 复杂元素;
174                     ** <complexType>
175                         <sequence>
176                             子元素
177                         </sequence>
178                        </complexType>
179                 - 简单元素,卸载复杂元素的中间
180                     <element name="person">
181                         <complexType>
182                             <sequence>
183                                 <element name="name" type="string"></element>
184                                 <element age="age" type="int"></element>
185                             </sequence>
186                           </complexType>
187                       </element>
188             (3) 在约束文件里面引入约束文件
189                 <person xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
190                 xmlns="http://www.itcast.cn/20151111"
191                 xis:schemaLocation="http://www.itcast.cn/20151111 1.xsd">
192 
193                 **解释:
194                 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
195                     - 表示xml是一个被约束的文件
196                 xmlns="http://www.itcast.cn/20151111"
197                     - 是约束文档里面targetNmaespace
198                 xis:schemaLocation="http://www.itcast.cn/20151111 1.xsd"
199                     - targetNmaespace+空格+约束文档的地址
200             * schema复杂元素指示器
201                 * <sequence>:表示元素的出现顺序
202                 * <all> 元素只能出现一次
203                 * maxOccurs="unbounded":表示元素的出现次数
204                 * <any></any>:表示任意元素
205             * 可以约束属性
206                 * 写在复杂元素里面;
207                 * 写在 <complexType>之前
208                 --- 
209                     <attribute name="id1" type="int" use="required">
210                         -- name :属性名称
211                         -- type: 属性类型 int string
212                         --  use :属性是否必须出现 required
213     
214                         
215 
216 * XML解析简介(写java代码)***
217     * xml是表机型文档
218     * 就是使用dom解析表机型文档
219         - 根据html的层级结构,在内存中分配一个树形结构.把html的标签,属性和文本都封装成对象.
220         - document对象,element对象.属性对象.node节点对象;
221     * xml的解析就是dom和sax方法
222         * dom层级结构解析,在内存中分配一个树形结构,吧xml的标签,属性文本都会封装成对象.
223             优点:可以增删改操作
224             缺点:文件过大时会内存溢出
225         * sax一行一行从上往下边读边解析:
226             优点:不会内存溢出.
227             缺点:不能增删改.
228     ** 不同的公司对dom和sax技术用不同的解析器:
229         - sun公司提供的是dom和sax解析器:  jaxp
230         - dom4j组织,针对dom和sax解析器:   dom4j(经常用)
231         - jdom组织,针对dom和sax解析器:    jdom
232 
233 
234 * jaxp的api的查看;java代码 不能使用var了  使用的是w3才包
235     ** jaxp是Javase的一部分
236       ** jaxp解析器在jdk的javax.xml.parsers包里面
237         ** 四个类; 分别是针对dom和sax解析使用类
238         document:操作:
239             查询:
240                 步骤:
241                     1.创建解析器工厂
242                     2.根据解析器工厂创建解析器
243                     3.解析xml,返回document
244                     4.得到所有neam元素
245                     5.使用返回集合里面的方法item(),下标获取具体元素
246                         NodeList.item(i);集合下标i从0开始
247                     6.得到具体的值,使用getTextContent方法

 

XML

标签:

原文地址:http://www.cnblogs.com/czb2580/p/5878869.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!