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

DTD(Document Type Definition,文档类型定义)用于定义XML文档的结构和合法元素。它规定了哪些元素可以出现在文档中、元素的属性、元素之间的嵌套关系以及元素内容的类型。虽然现在更推荐使用XML Schema,但DTD仍被广泛支持且简单易用。
1. 如何在XML中引用DTD
DTD可以在XML文档内部声明(内部DTD),也可以单独存放在外部文件中(外部DTD),然后通过DOCTYPE引用。
内部DTD示例:在XML文件开头使用声明,并在其中定义结构:
]>
将DTD保存为独立文件,比如book.dtd:
在XML中引用该DTD:
2. DTD中常用元素声明语法
DTD通过定义元素及其内容模型。
CPWEB企业网站管理系统(以下称CPWEB)是一个基于PHP+Mysql架构的企业网站管理系统。CPWEB 采用模块化方式开发,功能强大灵活易于扩展,并且完全开放源代码,面向大中型站点提供重量级企业网站建设解决方案。CPWEB企业网站管理系统 2.2 Beta 测试版本,仅供测试,不建议使用在正式项目中,否则发生任何的后果自负。
- (#PCDATA):仅包含文本内容
-
EMPTY:空元素,如
- ANY:可包含任意内容(不推荐,削弱约束)
-
子元素列表:如
(title, author+)表示title后跟一个或多个author
-
:note必须包含to、from、body,按顺序出现一次 -
:author元素只能包含文本 -
:book必须包含至少一个chapter
3. DTD中属性声明
使用为元素定义属性,包括属性名、类型和默认值。
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强大,但在简单场景下依然实用。









