两种方式:
1. 单独写一个.dtd文件
2. 在xml中写dtd。
引用DTD约束
XML文件使用DOCTYPE声明语句来指明它所遵循的DTD文件。DOCTYPE声明语句有两种形式:
当引用的文件在本地时,采用:
<!DOCTYPE 文档根结点 SYSTEM "DTD文件的URL">
<!DOCTYPE 文档根结点 PUBLIC "DTD名称" "DTD文件的URL">
当引用一个公共的文件时,采用如下方式:
<!DOCTYPE 文档根结点 PUBLIC "DTD名称" "DTD文件的URL">
<!DOCTYPE web-app PUBLIC '
“-//Sun Microsystems,Inc.//DTD Web Application 2.3//EN”
“http://java.sun.com/dtd/web-app_2_3.dtd“`
DTD约束语法细节
元素定义
在DTD文档中使用ELEMENT声明一个XML元素,语法格式如下所示:
<!ELEMENT 元素名称 元素类型>
元素类型可以是元素内容、或类型
- 如为元素内容:则需要使用()括起来,如
<!ELEMENT 书架(书名,作者,售价)>
- 如为元素类型,则直接书写,DTD规范定义了如下几种类型:
EMPTY:用于定义空元素,例如
<br/><hr/>
ANY:表示元素内容为任意类型.
-
用逗号分隔,表示内容的出现顺序必须与声明时一致。
<ELEMENT MYFILE(TITLE,AUTHOR,EMAL)>
用|分隔,表示任选其一,即多个只能出现一个<!ELEMENT MYFILE(TITLE|AUTHOR|EMAIL)>
在元素中也可以使用+、*、?等符号表示元素出现的次数:
+:一次或多次(书+)
?:0次或多次(书?)
*:0次货多次(书*)也可以使用()批量设置,例如:
<!ELEMENT MYFILE((TITLE *,AUTHOR?,EMAIL)*|COMMENT)>
属性
XML文档中的标签属性通过ATTLIST为其设置属性
- 语法格式:
@H_404_100@<!ATTLIST 元素名
属性名1 属性值类型 设置说明
属性名2 属性值类型 设置说明
........
@H_404_100@>
- 属性声明例子:
<!ATTLIST 商品
类别 CDATA #required
颜色 CDATA #IMPLIED
>
对应XML文件:
<商品 类别="服装" 颜色="黄色">...</商品>
<商品 类别="服装">....</商品>
设置说明:
<!ATTLIST 页面作者
姓名 CDATA #IMPLIED
年龄 CDATA #IMPLIED
联系信息 CDATA #required
网站职务 CDATA #FIXED “页面作者”
个人爱好 CDATA “上网”
>
常用属性值类型:
CDATA:表示属性值为普通文本字符串
ENUMERATED
ID
ENTITY
例子:
<?xml version="1.0" encoding="GB2312" standalone="yes">
<!DOCTYPE 购物篮[
<!ELEMENT 肉 EMPTY>
<!ATTLIST 肉 品种(鸡肉|牛肉|猪肉|鱼肉)“鸡肉”>
]>
<购物篮>
<肉 品种=“鱼肉”/>
<肉 品种=“牛肉”/>
<肉/>
</购物篮>
<?xml version="1.0" encoding="GB2312" standalone="yes">
<!DOCTYPE 联系人列表[
<!ELEMENT 联系人列表 ANY>
<!ELEMENT 联系人(姓名,EMAIL)>
<!ELEMENT 姓名(#PCDATA)>
<!ELEMENT EMAIL(#PCDATA)>
<!ATTLIST 联系人 编号 ID #required>
]>
<联系人列表>
<联系人 编号=“a1”/>
<姓名>张三</姓名>
<EMAIL>zhang@gmail.com</EMAIL>
</联系人>
</联系人列表>
实体ENTITY
实体用于为一段内容创建一个别名,以后再XML文档中就可以使用别名引用这段内容了
在DTD定义中,一条<!ENTITY ...>
语句用于定义一个实体
实体分为两种类型:引用实体和参数实体引用实体:
语法:
@H_404_100@<!ENTITY copyright "I am a programmer"@H_404_100@>
......
@H_404_100@©right;
- 参数实体: 参数实体是DTD自身用的 语法格式: