本文主要是介绍javaweb-day01-4(DTD 的语法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
XML 文件中 DOCTYPE 声明语句的格式:
XML 文件使用 DOCTYPE 声明语句来指定它所遵循的 DTD 文件。
DOCTYPE声明语句有两种形式:
1. 当引用的约束文件在本地硬盘时,使用如下方式:
<!DOCTYPE xml文档根节点 SYSTEM "dtd文档在本地的绝对路径或相对路径">
例如:<!DOCTYPE 书架 SYSTEM "book.dtd">
2. 当引用的约束文件是一个公共文件时,来自网上,使用如下方式:
<!DOCTYPE xml文档根节点 PUBLIC "dtd的名称" "dtd文件的URL地址">
dtd的名称:如果一个网站公布了一个dtd的时候,那么它一定会提供给你一个名称的。
DTD 的语法:
- 元素定义
- 属性定义
- 实体定义
元素定义:
格式:<!ELEMENT 元素名称 元素类型>
元素类型:可以是 元素内容 或 元素类型。
- 元素内容:用 ( ) 括起来,如:<!ELEMENT 书架 (书+)> 、 <!ELEMENT 书名 (#PCDATA)>
- 元素类型:直接写,包括:EMPTY(元素内容为空)、ANY(元素内容任意)
元素内容:
(1)分隔符:
- 以逗号分隔,表示内容的出现必须与声明时一致,如:<!ELEMENT 书 (书名,作者,售价)>
- 用 | 分隔,表示任选其一,即多个只能出现一个,如:<!ELEMENT 书 (书名|作者|售价)>
- 元素内容使用 空白符 分隔,表示出现顺序没有要求,如:<!ELEMENT 书 (书名 作者 售价)>
(2)次数设置:
在元素内容中也可以使用 + 、* 、? 等符号表示元素出现的次数:
- + : 一次或多次 (书+)
- ? : 0次或一次 (书?)
- * : 0次或多次 (书*)
也可使用圆括号( )批量设置,例如:<!ELEMENT 书 ((书名*, 作者?, 出版社)* | 简介)>
属性定义:
xml 文档中的标签 属性 需通过ATTLIST 为其设置属性。
格式:
<!ATTLIST 元素名
属性名1 属性值类型 设置说明
属性名2 属性值类型 设置说明
……
>
举例:
<!ATTLIST 商品 类别 CDATA #REQUIRED 颜色 CDATA #IMPLIED >
对应XML文件:<商品 类别="服装" 颜色="黄色">…</商品> <商品 类别="服装">…</商品>
设置说明:
- #REQUIRED:必须设置该属性
- #IMPLIED:可以设置也可以不设置
- #FIXED:说明该属性的取值固定为一个值,在 XML 文件中不能为该属性设置其它值。但需要为该属性提供这个值
- 直接使用默认值:在 XML 中可以设置该值也可以不设置该属性值。若没设置则使用默认值。
举例:
<!ATTLIST 页面作者 姓名 CDATA #IMPLIED 年龄 CDATA #IMPLIED 联系信息 CDATA #REQUIRED 网站职务 CDATA #FIXED "页面作者" 个人爱好 CDATA "上网" >
属性值类型:
- CDATA :表示属性值为普通文本字符串。
- ENUMERATED
- ID
- ENTITY :实体
ENUMERATED:枚举
<?xml version = "1.0" encoding="GB2312" standalone="yes"?>
<!DOCTYPE 购物篮 [<!ELEMENT 肉 EMPTY><!ATTLIST 肉 品种 ( 鸡肉 | 牛肉 | 猪肉 | 鱼肉 ) "鸡肉">
]>
<购物篮><肉 品种="鱼肉"/><肉 品种="牛肉"/><肉/>
</购物篮>
ID :
表示属性的设置值为一个唯一值。
属性的值只能由字母,下划线开始,不能出现空白字符。
<?xml version = "1.0" encoding="GB2312"?><!DOCTYPE 联系人列表[<!ELEMENT 联系人列表 ANY><!ELEMENT 联系人 (姓名,EMAIL)><!ELEMENT 姓名 (#PCDATA)><!ELEMENT EMAIL (#PCDATA)><!ATTLIST 联系人 编号 ID #REQUIRED> ]><联系人列表><联系人 编号="a"><姓名>张三</姓名><EMAIL>zhang@it315.org</EMAIL></联系人><联系人 编号="b"><姓名>李四</姓名><EMAIL>li@it315.org</EMAIL></联系人> </联系人列表>
ENTITY 实体:
实体用于为一段内容创建一个别名,以后在XML文档中就可以使用别名引用这段内容了。
在DTD定义中,一条<!ENTITY …>语句用于定义一个实体。
实体可分为两种类型:引用实体和参数实体。
引用实体:
主要在 XML 文档中被应用。
- 语法格式: <!ENTITY 实体名称 “实体内容” >
- 引用方式: &实体名称;
举例:
<!ENTITY copyright "I am a programmer">©right;
<?xml version = "1.0" encoding="GB2312"?><!DOCTYPE 联系人列表[<!ELEMENT 联系人列表 ANY><!ELEMENT 联系人 (姓名,EMAIL,公司)><!ELEMENT 姓名 (#PCDATA)><!ELEMENT EMAIL (#PCDATA)><!ELEMENT 公司 (#PCDATA)><!ATTLIST 联系人 编号 ID #REQUIRED><!ENTITY company1 "大中华有限公司"><!ENTITY company2 "中华烟草有限公司"> ]><联系人列表><联系人 编号="a" ><姓名>张三</姓名><EMAIL>zhang@it315.org</EMAIL><公司>&company1;</公司></联系人><联系人 编号="b" ><姓名>李四</姓名><EMAIL>li@it315.org</EMAIL><公司>&company2;</公司></联系人> </联系人列表>
<?xml version = "1.0" encoding="GB2312"?><!DOCTYPE 联系人列表[<!ELEMENT 联系人列表 ANY><!ELEMENT 联系人 (姓名,EMAIL)><!ELEMENT 姓名 (#PCDATA)><!ELEMENT EMAIL (#PCDATA)><!ATTLIST 联系人 编号 ID #REQUIRED公司 CDATA #REQUIRED><!ENTITY company1 "大中华有限公司"><!ENTITY company2 "中华烟草有限公司"> ]><联系人列表><联系人 编号="a" 公司="&company1;"><姓名>张三</姓名><EMAIL>zhang@it315.org</EMAIL></联系人><联系人 编号="b" 公司="&company2;"><姓名>李四</姓名><EMAIL>li@it315.org</EMAIL></联系人> </联系人列表>
参数实体:
被 DTD 文件自身使用。
- 语法格式: <!ENTITY % 实体名称 "实体内容" >
- 引用方式: %实体名称;
举例1:
<!ENTITY % TAG_NAMES "姓名 | EMAIL | 电话 | 地址"><!ELEMENT 个人信息 (%TAG_NAMES; | 生日)>
<!ELEMENT 客户信息 (%TAG_NAMES; | 公司名)>
举例2:
<!ENTITY % common.attributes"id ID #IMPLIED account CDATA #REQUIRED"
>
...
<!ATTLIST purchaseOrder %common.attributes;>
<!ATTLIST item %common.attributes;>
自己的例子:
about.dtd (注意选用 UTF-8 或 Unicode 编码格式保存)
<!ENTITY % contacts "姓名,EMAIL"><!ELEMENT 联系人列表 ANY>
<!ELEMENT 联系人 (%contacts;)>
<!ELEMENT 姓名 (#PCDATA)>
<!ELEMENT EMAIL (#PCDATA)><!ATTLIST 联系人 编号 ID #REQUIRED>
about.xml
<?xml version="1.0" encoding="GB2312"?><!DOCTYPE 联系人列表 SYSTEM "about.dtd"><联系人列表><联系人 编号="a"><姓名>张三</姓名><EMAIL>zhang@it315.org</EMAIL></联系人><联系人 编号="b"><姓名>李四</姓名><EMAIL>li@it315.org</EMAIL></联系人>
</联系人列表>
练习:
w3school 的 DTD.chm 文档的实例中有dtd文档,
根据dtd文档写出xml文档:
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE CATALOG [<!ENTITY AUTHOR "John Doe">
<!ENTITY COMPANY "JD Power Tools, Inc.">
<!ENTITY EMAIL "jd@jd-tools.com"><!ELEMENT CATALOG (PRODUCT+)><!ELEMENT PRODUCT
(SPECIFICATIONS+,OPTIONS?,PRICE+,NOTES?)><!ATTLIST PRODUCT
NAME CDATA #IMPLIED
CATEGORY (HandTool|Table|Shop-Professional) "HandTool"
PARTNUM CDATA #IMPLIED
PLANT (Pittsburgh|Milwaukee|Chicago) "Chicago"
INVENTORY (InStock|Backordered|Discontinued) "InStock"><!ELEMENT SPECIFICATIONS (#PCDATA)>
<!ATTLIST SPECIFICATIONS
WEIGHT CDATA #IMPLIED
POWER CDATA #IMPLIED><!ELEMENT OPTIONS (#PCDATA)>
<!ATTLIST OPTIONS
FINISH (Metal|Polished|Matte) "Matte"
ADAPTER (Included|Optional|NotApplicable) "Included"
CASE (HardShell|Soft|NotApplicable) "HardShell"><!ELEMENT PRICE (#PCDATA)>
<!ATTLIST PRICE
MSRP CDATA #IMPLIED
WHOLESALE CDATA #IMPLIED
STREET CDATA #IMPLIED
SHIPPING CDATA #IMPLIED><!ELEMENT NOTES (#PCDATA)>]><CATALOG><PRODUCT><SPECIFICATIONS></SPECIFICATIONS><PRICE></PRICE></PRODUCT><PRODUCT NAME="lala" CATEGORY="Table" PARTNUM="lala" PLANT="Pittsburgh" INVENTORY="Backordered"><SPECIFICATIONS WEIGHT="lala" POWER="lala">lala</SPECIFICATIONS><SPECIFICATIONS>lala</SPECIFICATIONS><OPTIONS FINISH="Metal" ADAPTER="Optional" CASE="NotApplicable">lala</OPTIONS><PRICE MSRP="la" WHOLESALE="la" STREET="la" SHIPPING="la">lala</PRICE><PRICE>la</PRICE><NOTES>la</NOTES></PRODUCT></CATALOG>
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE TVSCHEDULE [<!ELEMENT TVSCHEDULE (CHANNEL+)>
<!ELEMENT CHANNEL (BANNER,DAY+)>
<!ELEMENT BANNER (#PCDATA)>
<!ELEMENT DAY (DATE,(HOLIDAY|PROGRAMSLOT+)+)>
<!ELEMENT HOLIDAY (#PCDATA)>
<!ELEMENT DATE (#PCDATA)>
<!ELEMENT PROGRAMSLOT (TIME,TITLE,DESCRIPTION?)>
<!ELEMENT TIME (#PCDATA)>
<!ELEMENT TITLE (#PCDATA)>
<!ELEMENT DESCRIPTION (#PCDATA)><!ATTLIST TVSCHEDULE NAME CDATA #REQUIRED>
<!ATTLIST CHANNEL CHAN CDATA #REQUIRED>
<!ATTLIST PROGRAMSLOT VTR CDATA #IMPLIED>
<!ATTLIST TITLE RATING CDATA #IMPLIED>
<!ATTLIST TITLE LANGUAGE CDATA #IMPLIED>]><TVSCHEDULE NAME="la"><CHANNEL CHAN="la"><BANNER></BANNER><DAY><DATE></DATE><HOLIDAY></HOLIDAY></DAY></CHANNEL><CHANNEL CHAN="la"><BANNER>la</BANNER><DAY><DATE>la</DATE><HOLIDAY>la</HOLIDAY><HOLIDAY>la</HOLIDAY></DAY><DAY><DATE></DATE><PROGRAMSLOT><TIME></TIME><TITLE></TITLE></PROGRAMSLOT><PROGRAMSLOT VTR="la"><TIME>la</TIME><TITLE RATING="la" LANGUAGE="la">la</TITLE><DESCRIPTION>la</DESCRIPTION></PROGRAMSLOT></DAY></CHANNEL></TVSCHEDULE>
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE NEWSPAPER [ <!ELEMENT NEWSPAPER (ARTICLE+)>
<!ELEMENT ARTICLE (HEADLINE,BYLINE,LEAD,BODY,NOTES)>
<!ELEMENT HEADLINE (#PCDATA)>
<!ELEMENT BYLINE (#PCDATA)>
<!ELEMENT LEAD (#PCDATA)>
<!ELEMENT BODY (#PCDATA)>
<!ELEMENT NOTES (#PCDATA)> <!ATTLIST ARTICLE AUTHOR CDATA #REQUIRED>
<!ATTLIST ARTICLE EDITOR CDATA #IMPLIED>
<!ATTLIST ARTICLE DATE CDATA #IMPLIED>
<!ATTLIST ARTICLE EDITION CDATA #IMPLIED><!ENTITY NEWSPAPER "Vervet Logic Times">
<!ENTITY PUBLISHER "Vervet Logic Press">
<!ENTITY COPYRIGHT "Copyright 1998 Vervet Logic Press">]><NEWSPAPER><ARTICLE AUTHOR=""><HEADLINE></HEADLINE><BYLINE></BYLINE><LEAD></LEAD><BODY></BODY><NOTES></NOTES></ARTICLE><ARTICLE AUTHOR="&PUBLISHER;" EDITOR="&PUBLISHER;" DATE="©RIGHT;" EDITION="©RIGHT;"><HEADLINE>&NEWSPAPER;</HEADLINE><BYLINE>&PUBLISHER;</BYLINE><LEAD>&NEWSPAPER;</LEAD><BODY>&NEWSPAPER;</BODY><NOTES>©RIGHT;</NOTES></ARTICLE></NEWSPAPER>
这篇关于javaweb-day01-4(DTD 的语法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!