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”
>
4. 实际使用注意事项
DTD 虽然简单,但也有一些限制和使用建议:
- 不支持命名空间,与现代 XML 应用集成受限
- 数据类型支持有限,仅能区分文本和 ID 等少数类型
- 语法不是 XML 格式,容易出错且不易解析
- 适合小型项目或遗留系统,新项目建议使用 XML Schema
- 浏览器 和解析器通常支持 DTD 验证,可用于确保文档结构正确
基本上就这些。掌握 DTD 的核心是理解元素和属性的声明方式,以及如何在 XML 中正确引用。虽不如 Schema 强大,但在简单场景下依然实用。


