📄 0303-0100.htm
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0071)http://162.105.170.55/ASPs/GetLearningArticleTemp.asp?section=0303-0100 -->
<HTML><HEAD><TITLE>XML中国论坛 - 初学进阶 - 3.3.1 融众多元素命名于一体</TITLE>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<STYLE type=text/css>TABLE {
FONT-SIZE: 9pt; COLOR: black; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"
}
.pt9 {
FONT-SIZE: 9pt; COLOR: black; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"
}
.pt10 {
FONT-WEIGHT: 700; FONT-SIZE: 10pt; LINE-HEIGHT: 18pt; FONT-FAMILY: "宋体"
}
.TempOutline {
FONT-SIZE: 9pt; MARGIN-LEFT: 15pt; COLOR: #666666; TEXT-INDENT: -28pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
.TempOutline1 {
FONT-SIZE: 9pt; MARGIN-LEFT: 24pt; COLOR: #666666; TEXT-INDENT: -36pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
.Outline {
FONT-SIZE: 9pt; MARGIN-LEFT: 15pt; TEXT-INDENT: -28pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
.Outline1 {
FONT-SIZE: 9pt; MARGIN-LEFT: 24pt; TEXT-INDENT: -36pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
.Outline11 {
FONT-SIZE: 9pt; MARGIN-LEFT: 38pt; TEXT-INDENT: -50pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
.passage0 {
FONT-SIZE: 9pt; MARGIN-LEFT: 15pt; TEXT-INDENT: -28pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
.passage1 {
FONT-SIZE: 9pt; MARGIN-LEFT: 24pt; TEXT-INDENT: -36pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
.passage11 {
FONT-SIZE: 9pt; MARGIN-LEFT: 38pt; TEXT-INDENT: -50pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
.passage111 {
FONT-SIZE: 9pt; MARGIN-LEFT: 51pt; TEXT-INDENT: -64pt; LINE-HEIGHT: 15pt; FONT-FAMILY: "宋体"; TEXT-DECORATION: none
}
</STYLE>
<META content="Microsoft FrontPage 5.0" name=GENERATOR></HEAD>
<BODY vLink=#000000 aLink=#000000 link=#000000 leftMargin=0 topMargin=0
onload=""><!-- 以下为主体内容 -->
<div align="center">
<center>
<TABLE width="100%" border=0 style="border-collapse: collapse" bordercolor="#111111" cellpadding="0" cellspacing="0">
<TBODY>
<TR vAlign=top>
<TD width=50 rowSpan=2></TD>
<TD vAlign=center width=489>
<p align="center"><IMG height=33
src="image/title_learner.gif" width=226></TD>
<TD width=47 rowSpan=2></TD>
</TR>
<TR vAlign=top>
<TD width="489" ><!-- 正文内容 -->
<DIV class=pt10><B>3.3.1 融众多元素命名于一体</B></DIV>
<DIV></DIV><BR>
<DIV class=pt9>
<P>学了DTD又学Schema,忙得大家不亦乐乎。但回过头来看看本章的标题,或许读者要奇怪了,“海纳百川”,可“海”指的是什么?“川”又是什么?它们和DTD与Schema有关系吗?现在我们就来详详细细地讨论我们的“海”与“川”,“海”就是XML文件,“川”就是由DTD或者Schema进行的元素类型声明,而“海纳百川”便是说我们在同一个XML文件中可以使用多个DTD或Schema声明的元素类型。</P>
<P>前面我们讲到,XML较之HTML最根本的差别在于XML是定义置标语言的元语言,而HTML仅仅是由SGML元置标语言定义的一个实例语言。利用XML元置标语言,定义各种各样的XML实例的活动是相当开放的。针对不同的应用方向,每设计一个XML的DTD,一种新的置标语言便随之诞生。在各种各样XML实例置标语言如雨后春笋般不断涌现的过程中,将会产生这样一种应用需求,即在一个XML文档中,包含由多个DTD描述的元素。这个想法显然是达到“物尽其用”的一个好办法,它帮助我们最大程度地利用了现有的资源,正所谓“海纳百川,有容乃大”。</P>
<P>但是,这条锦囊妙计也会带来一定的问题。仍拿我们前面使用过的"联系人列表"的例子来说,现在我们需要知道每个联系人的直接上级,以便业务的顺利开展。于是,DTD中要为“联系人”元素增加一个子元素“直接上级”。修改后的DTD文件命名为“联系人列表.dtd”,源码如下:</P>
<DIV align=center>
<CENTER>
<TABLE width="80%" border=1>
<TBODY>
<TR>
<TD width="100%"><?xml version="1.0"
encoding="GB2312"?><BR><BR><!ELEMENT 联系人列表
(联系人)*><BR><!ELEMENT 联系人
(姓名,ID,公司,EMAIL,电话,地址,直接上级)><BR><!ELEMENT 地址
(街道,城市,省份)><BR><!ELEMENT 姓名 (#PCDATA)><BR><!ELEMENT ID
(#PCDATA)><BR><!ELEMENT 公司 (#PCDATA)><BR><!ELEMENT EMAIL
(#PCDATA)><BR><!ELEMENT 电话 (#PCDATA)><BR><!ELEMENT 直接上级
ANY><BR><!ELEMENT 街道 (#PCDATA)><BR><!ELEMENT 城市
(#PCDATA)><BR><!ELEMENT 省份
(#PCDATA)></TD></TR></TBODY></TABLE></CENTER></DIV>
<P>至于"直接上级"的内容,也就是这个元素的子元素,来自于另一个DTD声明,即"企业经理"的DTD声明。这个声明“企业经理.dtd”的文件为:</P>
<DIV align=center>
<CENTER>
<TABLE width="80%" border=1>
<TBODY>
<TR>
<TD width="100%"><?xml version="1.0"
encoding="GB2312"?><BR><BR><!ELEMENT 企业经理
(姓名,电话)><BR><!ELEMENT 姓名 (#PCDATA)><BR><!ELEMENT 电话
(秘书电话,手机)><BR><!ELEMENT 秘书电话 (#PCDATA)><BR><!ELEMENT 手机
(#PCDATA)></TD></TR></TBODY></TABLE></CENTER></DIV>
<P>这样一来,我们的"联系人列表"的例子可能会写成下面的样子:</P>
<DIV align=center>
<CENTER>
<TABLE width="80%" border=1>
<TBODY>
<TR>
<TD width="100%"><联系人列表><BR>
<联系人><BR> <姓名>张三</姓名><BR>
<ID>001</ID><BR>
<公司>A公司</公司><BR>
<EMAIL>zhang@aaa.com</EMAIL><BR>
<电话>(010)62345678</电话><BR>
<地址><BR>
<街道>五街1234号</街道><BR>
<城市>北京市</城市><BR>
<省份>北京</省份><BR>
</地址><BR> <直接上级><BR>
<姓名>王五</姓名><BR>
<电话><BR>
<秘书电话>(010)62345678</秘书电话><BR>
<手机>13601234567</手机><BR>
</电话><BR> </直接上级><BR>
</联系人><BR></联系人列表></TD></TR></TBODY></TABLE></CENTER></DIV>
<P>在这个例子中,“联系人”中有“姓名”和“电话”元素,而“直接上级”中也有“姓名”和“电话”元素。可是此“姓名”非彼“姓名”,此“电话”也非彼“电话”。尤其是“电话”元素,它们在语法语义上都是完全不同的。“联系人”元素中的“电话”子元素就是一个表示他电话号码的字符串,以方便与其联系;可是他的上级官职显要,电话的信息也比较多,包括秘书的电话和他的手机。对于XML文件的编写者和读者来说,凭借上下文的提示,对于这个差别尚能理解;但计算机可没有人那么聪明,面对两个“姓名”元素,它不知道哪个是“联系人列表”的DTD中定义的“姓名”,哪个又是“企业经理”的DTD中定义的“姓名”;它更会奇怪:“电话”怎么会摇身一变,成了“秘书电话”和“手机”的父元素?在这种情况下,我们称两个不同的元素在名称上发生了冲突。</P>
<P>如果不解决这种元素名称上的冲突问题,一个XML文档包含多个DTD中定义的元素这一天才构想就不能实现。为了解决这个问题,W3C的XML小组制定了被称为命名空间(NameSpace)的标准。W3C组织于1998年2月提出命名空间标准的第一个草案,到1999年1月14日正式发布为推荐标准。本章中介绍的命名空间,依照的就是这个推荐标准。</P></DIV>
<P></P>
<P></P></TD></TR></TBODY></TABLE>
</center>
</div>
<P></P>
<P>
<P></P></BODY></HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -