DTD-Document Type Definition,中文翻译即文档类型定义,可定义合法的XML文档构建模块。它使用一系列合法的元素来定义文档的结构。
DTD可以直接包含于XML源文件中,使用方法如下>
一个简单的例子如下
]>
George
John
Reminder
Don't forget the meeting!
也可以将DTD单独的写进一个外部文件中,只需要在XML里面导入即可。使用方法如下:
>
我们假设存在DTD文件名为 note.dtd ,内容如下:
则上面的包含DTD的XML可以写成:
George
John
Reminder
Don't forget the meeting!
所有的 XML 文档(以及 HTML 文档)均由以下简单的构建模块构成:
下面是每个构建模块的详细描述。
元素可包含文本、其他元素或者是空的。元素声明使用如下的语法:
或者是
如果一个元素不包含任何内容时,可以通过使用EMPTY来进行声明:
具体例子如:
对应的XML即为:
通过类别关键词 ANY 声明的元素,可包含任何可解析数据的组合:
带有一个或多个子元素的元素通过圆括号中的子元素名进行声明:
如上面的例子:
当子元素按照由逗号分隔开的序列进行声明时,这些子元素必须按照相同的顺序出现在文档中。在一个完整的声明中,子元素也必须被声明,同时子元素也可拥有子元素。"note" 元素的完整声明是:
例子:
上面的例子表明了 message子元素必须出现一次,而且只能在 note 元素中出现一次
例子:
上面的例子中的加号声明了:message 子元素必须在 "note" 元素内出现至少一次。
例子:
上面的例子中的星号声明了:子元素 message 可在 "note" 元素内出现零次或多次。
例子:
上面的例子中的问号声明了:子元素 message 可在 "note" 元素内出现零次或一次。
上面的例子标明了要么出现message,要么出现body。
属性可提供有关元素的额外信息。属性总是被置于某元素的开始标签中。属性总是以名称/值的形式成对出现的。
属性声明使用下列语法:
DTD 实例:
XML 实例:
以下是属性类型的选项:
类型 描述
CDATA 值为字符数据 (character data)
(en1|en2|..) 此值是枚举列表中的一个值
ID 值为唯一的 id
IDREF 值为另外一个元素的 id
IDREFS 值为其他 id 的列表
NMTOKEN 值为合法的 XML 名称
NMTOKENS 值为合法的 XML 名称的列表
ENTITY 值是一个实体
ENTITIES 值是一个实体列表
NOTATION 此值是符号的名称
xml: 值是一个预定义的 XML 值
默认值参数可使用下列值:
值 属性的默认值
#REQUIRED 属性值是必需的
#IMPLIED 属性不是必需的
#FIXED value 属性值是固定的
实体是用来定义普通文本的变量。实体引用是对实体的引用。大多数同学都了解这个 HTML 实体引用:" "。这个“无折行空格”实体在 HTML 中被用于在某个文档中插入一个额外的空格。当文档被 XML 解析器解析时,实体就会被展开。
PCDATA 的意思是被解析的字符数据(parsed character data)。可把字符数据想象为 XML 元素的开始标签与结束标签之间的文本。PCDATA 是会被解析器解析的文本。这些文本将被解析器检查实体以及标记。文本中的标签会被当作标记来处理,而实体会被展开。不过,被解析的字符数据不应当包含任何 &、< 或者 > 字符;需要使用 &、< 以及 > 实体来分别替换它们。
CDATA 的意思是字符数据(character data)。CDATA 是不会被解析器解析的文本。在这些文本中的标签不会被当作标记来对待,其中的实体也不会被展开。
如下是一个XML文件,我们考虑找出它的DTD。
Computer Science
Programming Methodology
Introduction to the engineering of computer applications emphasizing modern software engineering principles.
Programming Abstractions
Abstraction and its relation to programming.
Computer Organization and Systems
Introduction to the fundamental concepts of computer systems.
Introduction to Probability for Computer Scientists
From Languages to Information
Natural language processing. Cross-listed as .
Compilers
Principles and practices for design and implementation of compilers and interpreters.
Introduction to Databases
Database design and use of database management systems for applications.
Artificial Intelligence: Principles and Techniques
Structured Probabilistic Models: Principles and Techniques
Using probabilistic modeling languages to represent complex domains.
Machine Learning
A broad introduction to machine learning and statistical pattern recognition.
Alex
S.
Aiken
Jerry
R.
Cain
Daphne
Koller
Andrew
Ng
Eric
Roberts
Mehran
Sahami
Sebastian
Thrun
Jennifer
Widom
Julie
Zelenski
Electrical Engineering
Digital Systems I
Digital circuit, logic, and system design.
Digital Systems II
The design of processor-based digital systems.
William
J.
Dally
Mark
A.
Horowitz
Subhasish
Mitra
Oyekunle
Olukotun
Linguistics
From Languages to Information
Natural language processing. Cross-listed as .
Dan
Jurafsky
Beth
Levin
对应的DTD如下: