3.3.2.1 前缀标识法
命名冲突问题是XML文档中引入多DTD的老大难问题,那么,命名空间标准又是如何解决这一问题的呢?
一个直接的想法是保证所引用到的DTD没有重名的元素。可是,你所引用的DTD可能来自世界上各个地方,由不同的人制定,要求这成千上万的DTD没有重名现象似乎有些异想天开,且想想你身边重名的人还有多少呢!再有一个想法就是要求所引用到的DTD改名字,把“联系人列表”中的元素“姓名”改为“联系人姓名”,“电话”改为“联系人电话”;相应地,“企业经理”中的“姓名”改为“经理姓名”,“电话”改为“经理电话”。但是,如果出现了大量重名元素,这个修改的工作量就很大了,如此麻烦,多DTD的优势消失殆尽,还不如自己重新定义一个呢。
命名空间标准提供了一个很聪明的方法,就是所谓前缀标识法,即在元素名和属性名前面增加一个标识,以唯一区分当前元素或属性来自哪一个DTD。使用了命名空间后,上节那个"联系人列表"的例子就变成下面的样子。
<联系人:联系人列表 xmlns:联系人 ="联系人列表.dtd" xmlns:企业经理 ="企业经理.dtd">
<联系人:联系人>
<联系人:姓名>张三
<联系人:ID>001
<联系人:公司>A公司
<联系人:EMAIL>
zhang@aaa.com <联系人:电话>(010)62345678
<联系人:地址>
<联系人:街道>五街1234号
<联系人:城市>北京市
<联系人:省份>北京
<联系人:直接上级>
<企业经理:姓名>王五
<企业经理:电话>
<企业经理:秘书电话>(010)62345678
<企业经理:手机>13601234567
现在,由于在"直接上级"的"姓名"元素前增加了标识——"企业经理",而"联系人"的"姓名"元素前增加了标识——"联系人",这两个"姓名"在元素名称上的冲突被化解了。同样,语法分析器也会对两个“电话”元素识得庐山真面目,分别作不同的处理。
要实现元素、属性的前缀标识命名法,我们需要解决以下几个问题:
如何声明命名空间,即如何定义上例中的"联系人"、"企业经理"这样的前缀标识?
什么是合法名称,即标记中带有前缀标识的元素和属性应该是什么样子?
怎样使用合法名称,即在XML文档中应该如何发挥命名空间的威力?
下面的章节中,我们就来详细地讨论这几个问题。