DTD约束

1.DTD?
文件类型定义(约束)

2.xml?
xml:可扩展标记语言(不是JAVA语言,不遵守JAVA规则)
HTML:超文本标记语言(带标签的)

3.xml的俩种文档约束
DTD,Schema

4.XML格式要求(合法xml)
xml里的标签没有作用
html里的标签有作用
1.有且只有一个根节点
2.由开始标签和结束标签组成
3.xml区分大小写
4.正确嵌套标签

<!--根节点(persons)  -->
<persons>
	<person pid="p01" paddr="长沙" psex="男">
		<name>张三</name>
		<age>22</age>
		<contact>
			<phone>13722663816</phone>
		</contact>
		<br />
	</person>

5.使用DTD
5.1.在xml中加入DTD申明
1.内部申明:<! DCOTYPE root[]> root指的是跟标签
2.外部申明:<! DOCTYPE 文档根节点 SYSTEM “DTD文件名”>

5.2.元素定义语法 (DTD对元素的限制)

元素分类:EMPTY 空元素

(#PCDATA) 文本元素
(e1,e2) 混合元素
元素限制:,(顺序)
|(或,多选一)
?(0或1次)
*(0次或多次)

              申明一个元素

基本语法:<! ELEMENT 元素名称 元素类型>

              空元素
              
     <!ELEMENT 元素名称 EMPTY>

例子:: <!ELEMENT br EMPTY>
XML例子:

              只有 PCDATA 的元素
              
     只有 PCDATA 的元素通过圆括号中的 #PCDATA 进行声明:
             <!ELEMENT 元素名称 (#PCDATA)>
    例子: <!ELEMENT from (#PCDATA)>

             带有任何内容的元素

通过类别关键词 ANY 声明的元素,可包含任何可解析数据的组合:
<!ELEMENT 元素名称 ANY>
例子:<!ELEMENT note ANY>

           带有子元素(序列)的元素

带有一个或多个子元素的元素通过圆括号中的子元素名进行声明:
<!ELEMENT 元素名称 (子元素名称 1)>
例子:<!ELEMENT note (to,from,heading,body)>

          声明只出现一次的元素
           <!ELEMENT 元素名称 (子元素名称)>
           
例子:<!ELEMENT note (message)>

注:上面的例子声明了:message 子元素必须出现一次,并且必须只在 “note” 元素中出现一次。

         声明最少出现一次的元素
        <!ELEMENT 元素名称 (子元素名称+)>

例子:<!ELEMENT note (message+)>

注:上面的例子中的加号声明了:message 子元素必须在 “note” 元素内出现至少一次。

     声明出现零次或多次的元素
   <!ELEMENT 元素名称 (子元素名称*)>

例子:<!ELEMENT note (message*)>

注:上面的例子中的星号声明了:子元素 message 可在 “note” 元素内出现零次或多次。

  声明出现零次或一次的元素
<!ELEMENT 元素名称 (子元素名称?)>

例子:<!ELEMENT note (message?)>

注:上面的例子中的问号声明了:子元素 message 可在 “note” 元素内出现零次或一次。

 声明“非.../既...”类型的内容

例子:<!ELEMENT note (to,from,header,(message|body))>

注:上面的例子声明了:“note” 元素必须包含 “to” 元素、“from” 元素、“header” 元素,以及非 “message” 元素既 “body” 元素

声明混合型的内容

例子:<!ELEMENT note (#PCDATA|to|from|header|message)*>

注:上面的例子声明了:“note” 元素可包含出现零次或多次的 PCDATA、“to”、“from”、“header” 或者 “message”。

5.3属性定义语法(DTD对属性的限制)
基本语法:<!ATTLIST 元素名称 属性名称 属性类型 设置说明>

属性类型:ID/CDATA/ENUM (男|女)

设置说明:#REQUIRED(必须)/#IMPLIED(可选)

在这里插入图片描述
在这里插入图片描述
规定一个默认的属性值
DTD:

<!ELEMENT square EMPTY> <!ATTLIST square width CDATA "0">

合法的 XML:

注:在上面的例子中,“square” 被定义为带有 CDATA 类型的 “width” 属性的空元素。如果宽度没有被设定,其默认值为0 。

#IMPLIED
语法

<!ATTLIST 元素名称 属性名称 属性类型 #IMPLIED>

例子
DTD:

<!ATTLIST contact fax CDATA #IMPLIED>

合法的 XML:

合法的 XML: 注:假如您不希望强制作者包含属性,并且您没有默认值选项的话,请使用关键词 #IMPLIED。

#REQUIRED
语法

<!ATTLIST 元素名称 属性名称 属性类型 #REQUIRED>

例子
DTD:

<!ATTLIST person number CDATA #REQUIRED>

合法的 XML:

非法的 XML: 注:假如您没有默认值选项,但是仍然希望强制作者提交属性的话,请使用关键词 #REQUIRED。

#FIXED
语法

<!ATTLIST 元素名称 属性名称 属性类型 #FIXED "value">

例子
DTD:

<!ATTLIST sender company CDATA #FIXED "Microsoft">

合法的 XML:

非法的 XML: 注:如果您希望属性拥有固定的值,并不允许作者改变这个值,请使用 #FIXED 关键词。如果作者使用了不同的值,XML 解析器会返回错误。

列举属性值
语法:

<!ATTLIST 元素名称 属性名称 (en1|en2|..) 默认值>

DTD 例子:

<!ATTLIST payment type (check|cash) "cash">

XML 例子:

或者

注:如果您希望属性值为一系列固定的合法值之一,请使用列举属性值。

6.DTD实体

实体是用于定义引用普通文本或特殊字符的快捷方式的变量。

实体引用是对实体的引用。

实体可在内部或外部进行声明。

在这里插入图片描述
一个内部实体声明
语法:

<!ENTITY 实体名称 "实体的值">

例子:
DTD 例子:

<!ENTITY writer "Bill Gates"> <!ENTITY copyright "Copyright W3School.com.cn">

XML 例子:

&writer;&copyright;
注释: 一个实体由三部分构成: 一个和号 (&), 一个实体名称, 以及一个分号 (😉。

一个外部实体声明
语法:

<!ENTITY 实体名称 SYSTEM "URI/URL">

例子:
DTD 例子:

<!ENTITY writer SYSTEM "http://www.w3school.com.cn/dtd/entities.dtd"> <!ENTITY copyright SYSTEM "http://www.w3school.com.cn/dtd/entities.dtd">

XML 例子:

&writer;&copyright;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值