传智168期JavaEE就业班 day05-XML 约束与解析

时间:2022-03-27 06:07:40

* 课程回顾:
* DOM解析HTML简介
* DOM 文档对象模型
* 解析器

* document对象
* getElementById("id的值"); 返回一个元素(标签)对象
* getElementsByName("name的名称"); 返回数组
* getElementsByTagName("标签名称"); 返回数组

* 创建元素对象
document.createElement("元素名称");
document.createTextNode("文本内容");
appendChild(node); 父节点调用该方法
insertBefore(new,old) 在指定的节点之前添加子节点

* Element对象
* 操作属性 setAttribute("","") 设置或者修改属性
getAttribute("属性名称");
removeAttribute("属性名称");

* 获取子节点
getElementsByTagName("子节点的元素名称");

* Node节点对象
* nodeName nodeType nodeValue
* parentNode 父节点(*****)

* appendChild(node); 父节点调用该方法
* insertBefore(new,old) 在指定的节点之前添加子节点
* replaceChild(new,old) 替换节点
* removeChild(node) 删除节点
* cloneNode(true或者false) 复制节点

* innerHTML 获取和设置文本内容
<span></span>

* 事件
* onclick 点击事件
* ondblclick 双击事件
* onload 加载事件
* onfoucs 获取焦点
* onblur 失去焦点
* onchange 改变事件

* onsubmit 控制表单的提交

=============================================================================================================
* onsubmit事件
* 控制表单提交。 需要把onsubmit作用在表单上 <form onsubmit="">
* 值的写法:onsubmit="return run()"
* run()必须要有返回值,必须返回true或者false。
* 如果返回是true,表单可以提交,如果返回false,表单不能提交。如果没有返回值,默认是表单提交。
* run()的逻辑写什么?
* 表单的校验。

* 可以通过js提交表单。
// 通过id获取form
// var form = document.getElementById("formId");
// 通过form的name的属性获取表单
var form = document.form1;
//var name = document.form1.username.value;
//alert(name);

// 设置提交的路径
form.action = "success.html";
form.method = "get";
// 提交表单
form.submit();

* XML(*****)

* XML的简介
* XML 可扩展的标记语言。(和HTML非常类似的)
* 可扩展的。
* 自定义的标签。

* XML传输数据,HTML是显示数据。

* XML的版本: XML1.0(使用该版本) XML1.1(不向下兼容)
* 做什么用?
* 描述有关系的数据

* 应用
* 作为配置文件。

* 可以在系统与系统之间进行数据的传输。
* webserivice soap XML封装数据
* json 和XML概念

* XML的语法
* 文档声明(*****)
* 写法: <?xml version="1.0" ?>
* 文档声明必须出现在xml文件的第一行和第一列的位置。

* 属性:
* version="1.0" XML的版本 (必须写)
* encoding="UTF-8" 编码集 (可选的)
* standalone="yes或者no" 代表xml的文件是否是独立的。(如果是no,不独立,可以引入外部的文件)(可选的)
* 因为不写该属性,可以引入外部的文件。

* 乱码会伴随你们一生?
* 产生的原因:保存文件时和打开文件时采用的编码不一致。
* 解决办法:保存文件可打开文件采用的编码一致就ok。(MyEclipse不会产生乱码问题)

* 元素(***)
* 开始标签和结束标签。
* 包含标签主体: <abc>文本</abc>
* 不包含标签主体: <abc/>

* 不能交叉嵌套
* 只能有一个根元素(必须有,并且只能有一个)

* 命名规范:
* 区分大小写 错误的:<a></A> 代表两个标签
* 不能以数字和-中划线开头 错误的:<1a> <-a>
* 不能以XML(Xml XML xml)开头 错误的:<xmlaa>
* 不能包含空格和冒号。

* 属性(***)
* 自定义:命名规范同上。
* 在同一个元素上,不能有相同的属性。(*****)
* 可以使用双引号或者单引号。

* 注释(*)
* 和HTML的注释相同
<!-- XML的注释 -->

* 注释不能嵌套。

* 特殊字符
* < &lt;
* > &gt;
* & &amp;
* " &quot;
* ' &apos;

* CDATA区
* 把标签中的内容作为字符串。
* 语法:
<![CDATA[
内容:当成字符串
]]>

* PI(处理指令)(忘了)
* 替换HTML

* XML的约束
* DTD
* schema

<myspring>
<bean>hello.java</bean>
<猫/>
</myspring>

* 格式良好的XML:遵循语法规范。
* 有效的XML:有约束。

* DTD的约束
* 快速入门
* 快速入门的步骤:
* 需要出现哪些标签?
* 在DTD的文件中编写元素
<!ELEMENT 元素名称 元素类型>
* 判断元素是否是复杂还是简单元素?
* 如果是简单元素:(#PCDATA) 代表是字符串
* 如果是复杂元素:(子节点)

* 需要在book.xml引入DTD的文件
* <!DOCTYPE 根节点 SYSTEM "DTD文件的地址">

* DTD与XML文档的关联方式
* 可以在XML的文件中直接书写DTD的代码。(经常使用)
<!DOCTYPE 根节点 [
DTD的代码
]>

* 引入本地的DTD文件(经常使用)
<!DOCTYPE 根节点 SYSTEM "DTD文件的地址">

* 引入网络上的DTD文件
<!DOCTYPE 根节点 PUBLIC "DTD文件名称" "DTD文件的地址">

* 元素定义
* 语法:<!ELEMENT 元素名称 元素类型>

* (#PCDATA) 字符串
* EMPTY 空
* ANY 任意的
* (子元素)

* 子元素:
* 子元素之间的关系
* , 子元素出现是有顺序的
* | 子元素只能出现一个

* 子元素出现的次数
* + 子元素出现1次或多次
* * 子元素出现0次或多次
* ? 子元素出现0次或1次

<!ELEMENT MYFILE ((TITLE*, AUTHOR?, EMAIL)* | COMMENT)>

<MYFILE>
<TITLE></TITLE>
<AUTHOR></AUTHOR>
<EMAIL></EMAIL>
<TITLE></TITLE>
<AUTHOR></AUTHOR>
<EMAIL></EMAIL>
<TITLE></TITLE>
<AUTHOR></AUTHOR>
<EMAIL></EMAIL>
</MYFILE>

* 属性定义(AttributeList)
* 写法: <!ATTLIST 元素名称
属性名称 属性类型 属性约束
属性名称 属性类型 属性约束
>
* 属性类型
* CDATA 字符串
* 枚举(没有提供关键字) (男人|女人)
* ID 代表唯一的值,不能只写数字

* 属性的约束
* #REQUIRED 必须出现的
* #IMPLIED 可选的
* #FIXED 固定值 #FIXED "值"
* 默认值(不用)

* 实体定义(用的不多)
* <!ENTITY 别名 "值" >
* 需要在xml中引入别名,浏览器打开文件后,在引入的位置上显示值的。

* 解析XML
* 解析XML的方式有哪些呢?
* 常用的有两种?DOM和SAX
* 区别:
DOM解析XML
* 在内存中形成树状结构
* 缺点:如果文档过大,容易产生内存溢出的问题。
* 优点:方便做增删改的操作

SAX解析
* 基于事件驱动,边读边解析
* 优点:不会产生内存溢出问题。
* 缺点:不能做增删改操作。(DOM4J在内存生成树状结构)

*,只能使用DOM方式,如果SAX,只能做查询。
* DOM4J(*****) JAXP SUN提供的
* 想做增删改 企业都在用。DOM4J提供的
* 全部都可以做。
* JDOM(不讲了)

* JAXP的解析HTML
* DOM
* DocumentBuilderFactory :解析器工厂类
* DocumentBuilder 获取解析器对象
* 解析XML(Document parse(String uri) )
// 获取解析器工厂类
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
// 获取解析器对象
DocumentBuilder builder = factory.newDocumentBuilder();
// 解析XML的文档,返回document对象
Document document = builder.parse("src/book2.xml");

* 回写
* 获取回写的工厂类
* 获取回写对象
* 调用回写的方法进行回写。
// 创建回写类的工厂
TransformerFactory transformerFactory = TransformerFactory.newInstance();
// 获取回写类
Transformer transformer = transformerFactory.newTransformer();
// 调用回写的方法
transformer.transform(new DOMSource(document), new StreamResult("src/book2.xml"));

* 作业:Node insertBefore(Node newChild, Node refChild)
在指定的节点之前添加子节点

* 更新节点的内容

* 获取标签的属性值