|
<title>Localize ASP with XML</title>
<firstname>First name</firstname>
最后,良好格式的XML文档包含了一整套对应于HTML页面的字符串。下图显示了XML文件中的标记和English语言字符 串。注重,现在这里只讨论English版本,以后可以添加更多种语言。
ASP文件代码分析 现在回来看看ASP文件xmltrans.asp。在其中我们使用XML路径语言(XPath),它可以在微软的XML解析器(MSXML)中 执行。你可以认为XPath是抵达XML文档一部分内容预定位置的工具,这有些类似于在命令行中输入一个路径以执行文件, 比如c:winntnotepad.exe,或者在浏览器中敲入了一个URL访问页面。下面研究这个ASP文件看看如何取回English语言字 符串。首先,我们实例化一个叫做MSXML2.DOMDocument的XML解析器工作对象:
set doc=server._
CreateObject _
("MSXML2.DOMDocument")
由于ASP程序不能象Win32程序一样处理事件,所以在这里我们关闭了异步操作选项。这样就确保了在转向其他任务 前,脚本程序会一直等待当前事件的完成:
doc.async = False
接着使用DOMDocument对象的Load方法装载包含字符串的XML文档。假如转载过程中发生了错误,就发出警告信息并停 止运行:
if not doc.Load(server._
mappath("xmltrans.xml")) then
msg="Failed to load "
msg=msg & "the XML file"
Response.Write msg
Response.End
end if
我们可以使用两种方法查询XML文档:XSL和XPath。在这里让解析器使用后者,传递属性名字和正确数值给 setProperty方法:
doc.setProperty _
"SelectionLanguage", "XPath"
然后,创建选择XML文档部分内容的路径。很明显,相关字符串位于languages元素的某个位置内,因此languages成为 路径的最开始部分。同时我们知道字符串是被包含在一个language元素内的,但是是哪一个呢?请别忘记在前面的XML文档 中,我们嵌入了一个叫做xml:lang的属性,并给出了一个唯一数值“en”。这就是我们要选择的,下面是操作它的语法:
sel="/languages/language"
sel=sel & "[@xml:lang='en']"
这有些不好理解,但你可以将这段XPath代码想像为一个SQL语句,类似于取回一个记录集的命令:
SELECT * FROM languages.language WHERE xml:lang='en'
回到现实的XPath查询,要使用下面的代码返回包含第一个匹配节点的节点对象:
set selectednode = _
doc.selectSingleNode(sel)
最后一步是传递元素名字("title")给selectSingleNode方法,并要求它取回"title"节点的text属性值。就是说,取 得包含在<title>和</title>的文字。在这里,取回的文字是"Localize ASP with XML":
txt=selectednode._
selectSingleNode("title").text
与SQL命令对照,就象从ADO记录集内部取回一个字段值,语句是:
txt=rs("title")
在ASP页面中插入语言字符串 知道了如何从XML元素中选取文字并赋值给变量,就可以将变量值插入到HTML流中了。为了使代码简洁,创建一个叫做
|
| 共5页: 上一页 [1] [2] 3 [4] [5] 下一页 |
评论加载中…