DTD通过声明元素和属性定义xml结构,可在文档内嵌或外部引用;使用<!ELEMENT>定义元素内容模型,<!ATTLIST>声明属性类型与默认值;尽管语法简单且广泛支持,但因缺乏命名空间和数据类型限制,现多推荐用于小型项目或遗留系统。

DTD(Document Type Definition,文档类型定义)用于定义XML文档的结构和合法元素。它规定了哪些元素可以出现在文档中、元素的属性、元素之间的嵌套关系以及元素内容的类型。虽然现在更推荐使用XML Schema,但DTD仍被广泛支持且简单易用。
1. 如何在XML中引用DTD
DTD可以在XML文档内部声明(内部DTD),也可以单独存放在外部文件中(外部DTD),然后通过DOCTYPE引用。
内部DTD示例:
在XML文件开头使用<!DOCTYPE>声明,并在其中定义结构:
<?xml version=”1.0″ encoding=”UTF-8″?>
<!DOCTYPE book [
<!ELEMENT book (title, author, price)>
<!ELEMENT title (#PCDATA)>
<!ELEMENT author (#PCDATA)>
<!ELEMENT price (#PCDATA)>
]>
<book>
<title>javaScript入门</title>
<author>张三</author>
<price>59.9</price>
</book>
外部DTD示例:
将DTD保存为独立文件,比如book.dtd:
<!ELEMENT book (title, author, price)>
<!ELEMENT title (#PCDATA)>
<!ELEMENT author (#PCDATA)>
<!ELEMENT price (#PCDATA)>
在XML中引用该DTD:
<?xml version=”1.0″ encoding=”UTF-8″?>
<!DOCTYPE book SYSTEM “book.dtd”>
<book>
<title>javascript入门</title>
<author>张三</author>
<price>59.9</price>
</book>
2. DTD中常用元素声明语法
DTD通过<!ELEMENT>定义元素及其内容模型。
常见元素类型:
- (#PCDATA):仅包含文本内容
- EMPTY:空元素,如
<br/> - ANY:可包含任意内容(不推荐,削弱约束)
- 子元素列表:如
(title, author+)表示title后跟一个或多个author
例子:
-
<!ELEMENT note (to, from, body)>:note必须包含to、from、body,按顺序出现一次 -
<!ELEMENT author (#PCDATA)>:author元素只能包含文本 -
<!ELEMENT book (chapter+)>:book必须包含至少一个chapter
3. DTD中属性声明
使用<!ATTLIST>为元素定义属性,包括属性名、类型和默认值。
语法:
<!ATTLIST 元素名 属性名 类型 默认值>
示例:
<!ATTLIST book
id ID REQUIred
category CDATA #IMPLIED
status (published|draft) “draft”
>
- ID:唯一标识符,每个ID在整个文档中必须唯一
- CDATA:普通文本
- 枚举类型:如(status)限定取值范围
- 默认值选项:
- REQUIRED:必须提供
- #IMPLIED:可选
- “default”:指定默认值
4. 实际使用注意事项
DTD虽然简单,但也有一些限制和使用建议:
- 不支持命名空间,与现代XML应用集成受限
- 数据类型支持有限,仅能区分文本和ID等少数类型
- 语法不是XML格式,容易出错且不易解析
- 适合小型项目或遗留系统,新项目建议使用XML Schema
- 浏览器和解析器通常支持DTD验证,可用于确保文档结构正确
基本上就这些。掌握DTD的核心是理解元素和属性的声明方式,以及如何在XML中正确引用。虽不如Schema强大,但在简单场景下依然实用。


