XML中的常见问题 (四)
作者: 来源: 添加时间:2006-5-21 20:25:59在用 DOM 从零开始构造文档以产生 XML 文件时,任何内容都在一行上,相互之间没有空格。这是默认的行为。
构造在 Internet Explorer 5 中的默认 XSL 样式表,以可读格式显示和打印 XML 文档。例如,如果已经安装了 IE5,请尝试查看 nospace.xml 文件。浏览器中应该显示下面的树:
-
-
XYZ
12.56
在 XML 中没有插入空白字符。
打印可读 XML 是非常有趣的,特别是有定义不同类型内容模型的 DTD 时。例如,在混合内容模型 (#PCDATA) 下不能插入空格,因为它可能改变内容的含义。比如请考虑下面的 XML:
Elephant
这最好不输出为:
E
lephant
因为单词边界不再正确。
所有这些都使自动化打印成为问题。如果不需要打印可读 XML,那么可以使用 DOM 在适当的位置插入空白字符作为文本节点。
如何在 DTD 中使用名称空间? 要在 DTD 中使用名称空间,请在使用它的元素的 ATTLIST 声明中声明它,如下所示:
名称空间类型必须为 #FIXED。属性的名称空间也是这样:
名称空间和 XML 架构
DTD 和 XML 架构不能混合。例如,下面的
| xmlns:x CDATA #FIXED "x-schema:myschema.xml" |
将不导致使用在 myschema.xml 中定义的架构定义。对 DTD 和 XML 架构的使用是互斥的。
如何在 Visual Basic 中使用 XMLDSO?
使用下面的 XML 作为例子:
| Mark Hanson 206 765 4583 Jane Smith 425 808 1111 |
可以按如下方式绑定到 ADO 记录集:
创建新的 VB 6.0 项目。
添加对 Microsoft ActiveX Data Objects 2.1 或更高版本、Microsoft Data Adapter Library 和 Microsoft XML 2.0 版的引用。
用下面的代码将 XML 数据加载到 XML DSO 控件中:
| Dim dso As New XMLDSOControl Dim doc As IXMLDOMDocument Set doc = dso.XMLDocument doc.Load ("d:\\test.xml") |
用下面的代码将 DSO 映射到使用 DataAdapter 的新记录集对象中:
| Dim da As New DataAdapter Set da.Object = dso Dim rs As New ADODB.Recordset Set rs.DataSource = da |
访问数据:
| MsgBox rs.Fields("name").Value |
结果显示字符串“Mark Hanson”
如何在 Java 中使用 XML DOM?
必须已经安装 MSXML.DLL 的 IE5 版本。在 Visual J++ 6.0 中,从项目菜单选择添加 COM 包装程序,然后从 COM 对象列表中选择“Microsoft XML 1.0”。该操作将把所需的 Java 包装程序构造到称为“msxml”的新软件包中。这些预先构造的 Java 包装程序也可以下载。类可以按如下方法使用:
import com.ms.com.*;
import msxml.*;
public class Class1
{
public static void main (String[] args)
{
DOMDocument doc = new DOMDocument();
doc.load(new Variant("file://d:/samples/ot.xml"));
System.out.println("Loaded " + doc.getDocumentElement().getNodeName());
}
}