1.知识点回顾(html和xml)
html: 主要负责网页的结构。
css:主要负责网页的美观/样式。
javascript: 主要负责在浏览器端与客户进行交互
以上三门语言都是静态网页制作的语言。
html语言特点:
1)由标签组成。<p></p> <br/> <h2></h2>。由w3c组成规定的!
2)html语言语法结构松散的。
<html>
<p>
</HTML>
总结:大小写不区分,标签可以不配对。浏览器帮我们修正html页面
其他自定义标签能不能被解析?这些自定义标签就是XML标签。
XML标签:Extend Markup Language 可扩展标记语言
2.html和xml的区别
HTML语言 XML语言
缩写: 超文本标记语言 可扩展标记语言
标记的范围: 由w3c组成指定的标签(固定的) 没有限制的,自定义标签。(符合xml语法的标签是可以的)
语法结构: 语法结构松散。(大小写不区分) 相对严谨(大小写区分)
作用(用途): 用于网页的结构 1)描述带关系的数据(作为软件的配置文件)
properties属性文件: 键值对。不能描述数据关系。
name=eric
password=1234
xml可以描述带关系数据。包含与被包含关系
<user>
<name>eric</name>
<password></password>
</user>
2)作为存储数据的容器。(作为小型的数据库)
3.xml的两个作用
1.描述带关系的数据(软件的配置文件)
例如:
把IP和端口写在xml文件中
dbhost.xml
<dbhost>
<ip>211.34.21.56</ip>
<port>1521</port>
</dbhost>
dbhost.xml文件作为学生管理系统的配置文件。
三大框架的软件配置文件,就是使用xml文件。
2.作为数据存储容器
xml(行业的数据规范)
teacher.xml
<teacher>
<name>张三</name>
<workage>3</workage>
<email>zhangsan@qq.com</email>
</teacher>
4.xml语法
总结:
xml后缀为.xml
使用浏览器去检查xml是否符合语法。因为浏览器内置了xml的解析引擎。
4.1.标签
xml的标签是自定义标签
语法: <student>张三</student>
注意:
1)严格区分大小写
2)标签名不能以数字开头。只能以字母或下划线开头,中文。
3)标签名不能包含空格
4)如果没有使用名称空间,标签名不能包含冒号
5)且在一个xml文档中,只允许有仅有一个根标签
4.2.属性
语法: <name id="001">lisi</name>
注意:
1)属性放在开始标签中。
2)属性值必须放在双引号或单引号中,不能省略引号,也不能单双混用。
3)在一个标签中,属性可以有多个,但不能出现同名的属性。
4.3.注释:
注释的格式
<!--xml的注释-->
4.4. 转义字符
转义字符:
< <
> >
" "
& &
空格  
4.5. CDATA块
CDATA块的作用,如果xml中的一段内容都希望原样输出,可以把这段内容包含在CDATA块中。
CADATA语法:
<![CDATA[
<itcast>
<br/>
</itcast>
]]>
4.6.文档声明
语法:<?xml version="1.0" encoding="utf-8"?>
version: 表示xml的版本号
encoding: 浏览器打开xml文件时(解码)查询码表
xml文档编码问题注意:
1)ecplise工具会自动根据xml文件的文档声明自动设置保存时的编码,所以在ecplise中编写xml文件通常不会有编码问题。
2)但是如果使用记事本工具,那么注意保存xml文件的编码和文件声明的编码保持一致!
4.7.处理指令
作用:主要告诉浏览器如何解析xml文件
希望提出出xml文件中对我们有用的内容,把标签忽略掉。
<?xml-stylesheet type="text/css" href="1.css"?>
告诉浏览器该xml文档引用哪个css文档
注意:
使用了处理指令,xml文档和html文档的作用就类似了,都可以作为网页的结构。但xml的该功能基本已经不再使用了
5.xml解析
5.1xml解析入门
XML解析: xml文件除了给开发者看之外,更多的是使用程序去读取或操作。
5.2xml解析的方式
DOM解析:基于DOM模型解析xml文件。
SAX解析:基于SAX的原理解析xml文件。
5.3xml解析工具
基于DOM解析:
1)Dom4j工具。非常流行的xml解析工具。
三大框架ssh,读取xml工具的就是dom4j
tomcat7或以上,使用dom4j读取xml文件。
2)JAXP工具(sun公司官方)
3)JDOM工具
基于SAX解析:
1)SAX解析工具(sun公司官方api)
.5.4Xpath技术
1 XPath的作用
XPath主要是用于快速查找到XML文档中的节点的技术
需求: 删除name标签,需要先得到根标签,再得到子标签, 再得到name标签
Document.getRootElement().element("contact").element("name");
2.XPath在dom4j中如何使用:
1)在项目中导入xpath支持jar包。jaxen-1.1-beta-6.jar
2)使用dom4j提供的xpath方法
selectNodes(xpath表达式): 查询符合条件的多个节点对象
selectSingleNode(xpath表达式) 查询符合条件的一个节点对象
5.3 XPath表达式语法:
/ 绝对路径 从根标签开始或子元素。
// 相对路径 不分层次结构的所有元素。
* 通配符 选择所有标签
[ ] 条件 选择带条件的元素。例如 first() last()
@ 属性 选择属性。
and 逻辑运算
5.5Dom解析
(xml解析引擎加载完毕xml文件时),会把xml文件中的各个部分封装成节点对象,然后通过节点对象获取或者设置标签,属性,文本内容,这就是dom解析模型)
5.6Sax解析
DOM解析: 一次性把xml文件加载进内存,然后在内存中构建Document树。比较消耗内存,并不适合读取容量大的xml文件。
SAX解析: 优势:内存占用非常小。加载一点,解析一点,处理一点,接着释放内存。
5.7Dom和Sax解析的区别
原理 一次性加载xml文档,内存占用比较大 加载一点,读取一点,处理一点,释放内存,内存占用较小
读取顺序 DOM可以任意在文档读取 甚至往回读 SAX解析从上往下依次读取,不能往回读
操作xml DOM解析可以增删改查操作 SAX解析只能读取
编程方法 基于对象编程模式,根据符合java开发者思维 基于事件编程模式,编程相对复杂。