XML加ASP实现网页“本地化”

想让你的站点能被来自多个国家的冲浪者看明白吗?无疑,这就需要提供多个语言版本的页面内容,也就是所谓的
“本地化”功能。最容易想到的方法就是分别编写多种语言的页面内容,然后放置到不同的目录下,再在首页上添加导航
到各自语言位置的链接。很明显,这样的处理方式将浪费许多包含公共元素以及设计框架的空间,而且修改、维护也很烦
琐。有什么好方法吗?当然,本文就介绍如何结合使用XML与ASP技术实现这个目的。 
本文将讨论如下几个方面的内容:创建包含语言资源的XML文档、使用ASP创建Web页面模板、使用XPath语法和MSXML3
分析器定位XML文档中的目标内容以及动态地在HTML流中插入语言字符串。 
准备条件 
本文讨论的技术涉及到以下方面:IIS4 或者 PWS(包含ASP功能),MSXML 版本 3。 
功能展示 
本文要讨论的例程是一个简单的HTML表单,用以提交名字和地址信息。下面是在Netscape Navigator中显示西班牙语
言的图示:
采用本文论述的技术,你就可以非常简单地通过更新一个XML文件实现为站点添加多种语言的功能。 
创建包含语言资源的XML文档 
首先,使用喜爱的页面编辑器创建一个叫做xmltrans.asp的Web页面文件。我发现使用静态占位符文字(比如"First 
name ")设计页面最容易。当XML准备好后,就可以使用变量替换这些静态文字。要下载例程文件请点击这里。 
完成基本页面的功能设计后,开始创建一个包含语言字符串的良好格式XML文档。在这里,我使用纯文本编辑器
Notepad编写初始的XML语言集-英语版本。Notepad使我感觉更接近于源代码。XML文件命名为xmltrans.xml。下面列出了
包含English、French和Spanish字符串的XML文件代码内容: 
<?xml version="1.0" encoding="UTF-8"?> 
<languages> 
 <language xml:lang="en" engname="English" langname="English" charset="Windows-1252"> 
 <title>Localize ASP with XML</title> 
 <firstname>First name</firstname> 
 <lastname>Last name</lastname> 
 <prefix>Prefix</prefix> 
 <suffix>Suffix</suffix> 
 <address1>Address</address1> 
 <address2>Address 2</address2> 
 <address3>Address 3</address3> 
 <city>City</city> 
 <region>State/Province</region> 
 <postalcode>Postal code</postalcode> 
 <areacode>Area code</areacode> 
 <telephone>Telephone number</telephone> 
 <submit>OK</submit> 
 <lang>en</lang> 
 <charset>Windows-1252</charset> 
 <langname>English</langname> 
 </language> 
 <language xml:lang="fr" engname="French" langname="franζais" charset="Windows-1252"> 
 <title>Localize ASP with XML - French</title> 
 <firstname>Prénom</firstname> 
 <lastname>Nom</lastname> 
 <prefix>Préfixe (M., Mme, Mlle)</prefix> 
 <suffix>Suffixe/Titre</suffix> 
 <address1>Rue</address1> 
 <address2/> 
 <address3/> 
 <city>Ville</city> 
 <region>Région/Province</region> 
 <postalcode>Code postal</postalcode> 
 <areacode>Indicatif régional</areacode> 
 <telephone>Numéro de téléphone</telephone> 
 <submit>OK</submit> 
 <lang>fr</lang> 
 <charset>Windows-1252</charset> 
 <langname>French</langname> 
 </language> 
 <language xml:lang="sp" engname="Spanish" langname="Espanol" charset="Windows-1252"> 
 <title>Localize ASP with XML - Spanish</title> 
 <firstname>Nombre</firstname> 
 <lastname>Apellido paterno</lastname> 
 <prefix>Prefijo (Sr., Sra., Srta.)</prefix> 
 <suffix>Sufijo o título</suffix> 
 <address1>Línea 1 de dirección</address1> 
 <address2/> 
 <address3/> 
 <city>Ciudad</city> 
 <region>Región, estado o provincia</region> 
 <postalcode>Código postal</postalcode> 
 <areacode>Código de área</areacode> 
 <telephone>Número de teléfono </telephone> 
 <submit>OK</submit> 
 <lang>sp</lang> 
 <charset>iso-8859-1</charset> 
 <langname>Spanish</langname> 
 </language> 
</languages> 
xmltrans.xml文件的第一行是XML声明。其中的version属性告诉读者文档符合XML 1.0的标准,encoding属性指示解析
器使用压缩版本的Unicode: 
<?xml version="1.0" encoding="UTF-8"?> 
一个XML文档需要一个包含其他元素的根元素。因为这里的例程是包含一些语言,所以就命名根元素为languages: 
<languages> 
作为集合类型,languages元素包含了一个或多个language元素: 
<language xml:lang="en" engname="English" langname="English" charset="Windows-1252"> 
以上language标记包含4个属性。xml:lang属性是其中最重要的,在ASP程序中将通过这个属性值的2字母语言代码搜索
字符串组。其他的属性,比如charset,可以为将来的功能扩充而用。 
每种语言节点中,我都添加了一个元素作为变量,其中含有显示在HTML页面上的文字。XML允许使用有含义的名字作为
自定义标记,比如,我使用<title>元素包含HTML页面的标题。同样,<firstname>元素包含字符串"First name"。 
<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:\winnt\notepad.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流中了。为了使代码简洁,创建一个叫做
getstring()的函数,如下: 
function getstring(instring) 
temp=selectednode._ 
selectSingleNode _ 
(instring).text 
getstring= _ 
server.htmlencode(temp) 
end function 
getstring()函数的输入值是元素名,元素值要从XML文档中取回。比如,将"firstname"传递给getstring(),
getstring函数就选择firstname元素并返回它的文本数值。为保险起见,在返回给调用者前,我们使用ASP的
server.htmlencode方法转换文本为合法的HTML代码。在ASP页面中,调用代码类似如下: 
<td> 
<%=getstring("firstname")%>: 
</td> 
如果选择了XML文档的English部分,HTML输出结果如下: 
<td>First name:v/td> 
如果选择了French,HTML输出结果如下: 
<td>Prénom:</td> 
下图显示了French语言版本的表单:

选择可用语言 
XML的一大优势就是它是以清晰的文本格式保存,我们能够在任何时候更新Web服务器上的XML文件。而且,我们还可以
将English版本的xmltrans.xml文件在XML编辑器XML NotHPad中打开,复制一份,然后将其中文字翻译为一种新语言。下图
显示了XML Notepad中的例程文件:

上图中,在左边可以执行添加、删除以及选择元素和属性的操作,在右边可以编辑相关内容。当站点需要多种语言版
本时,只需要在内容中执行粘贴操作,然后上载最新的XML文档就可以了。 
为了使添加的语言立即生效,要增加一个程序,用它判断文件中不同语言的种类数量,并返回语言代码和语言名称。
如下面的代码段所示,我们可以将数据格式化处理以创建一个HTML列表框。当用户提交表单时,2字母表示的语言种类代码
被存储到ASP会话变量choselang中。 
<select name="chosenlang"> 
<% 
for i=0 to selectednodes.length - 1 
 response.write "<option value=" & _ 
 chr(34) & _ 
 selectednodes.item(i)._ 
selectSingleNode("lang").text & chr(34) 
 if (selectednodes.item(i)._ 
selectSingleNode("lang").text = _ 
session("chosenlang")) then 
 response.write " selected>" 
 else 
 response.write ">" 
 end if 
 response.write selectednodes.item(i)._ 
selectSingleNode("langname").text & _ 
"</option>" & vbcrlf 
next 
%></select> 
添加提示信息以及字符集数据 
上面使用XML提供了HTML表单的可变语言文字显示,接着还要考虑一些更丰富的用途。比如说,要在选择语言时添加一
个提示信息,只需要在文字前后嵌入HTML标记<LABEL>,并从XML中提供可变内容作为title属性值。同理,为了帮助浏览器
识别HTML页面的语言种类,将字符集信息保存到XML文件中,比如: 
<charset>x-sjis</charset> 
然后,就可以使用ASP将字符集类型插入到HTML流中: 
<meta HTTP-EQUIV="Content-Type" content="text/html; charset= 
<%=getstring("charset")%>" /> 
最后的HTML代码包括了Japanese字符集参考: 
<meta HTTP-EQUIV="Content-Type" content="text/html; charset=x-sjis" /> 
下图显示了使用Japanese字符集的页面。记住,要看到正确的内容,操作系统以及浏览器必须支持Unicode并安装了相
应字符。否则,就会看到一些奇怪的文字,可能是一些问号,也可能是一些方块符号等等。

总结 
本文讲述了如何使用XML文件保存Web页面的语言字符串。从中我们学会了使用ASP脚本程序并借助微软XML解析器和W3C
的XPath语言实现查询XML文档的功能。ASP代码将包含字符集类型的可变文字插入到HTML流中,并形成列表框以让用户选择
可用语言。本文涵盖了许多内容,但我想这只是一个起点。虽然可以在支持XML的浏览器中简单地实现这些功能,但我们已
经看到:使用服务器端脚本可以转换XML数据为普通的HTML内容,即使是早期版本的浏览器,同样能够看到这些精彩内
容。

(0)

相关推荐

  • 学习使用ASP.NET 2.0的本地化

    譬如我有一个登陆页面,上面有两个Label和两个Textbox,页面命名为Login.aspx,控件命名为lbl_UserName,lbl_Password,txt_UserName,txt_Password. 首先可以在网站上新建一个App_LocalResources的文件夹,然后新建一个资源文件,命名为Login.aspx.resx 命名需要跟匹配的页面名字相同.然后再新建另一个资源文件,命名为Login.aspx.zh-Cn.resx Login.aspx.resx 这个为默认的,而Lo

  • ios多种语言的本地化思路

    多语言在应用程序中一般有两种做法: 一.程序中提供给用户自己选择的机会: 二.根据当前用户当前移动设备的语言自动将我们的app切换对应语言. 第一种做法比较简单完全靠自己的发挥了,这里主要讲第二种做法,主要分一下几点: 1.本地化应用程序名称 2.本地化字符串 3.本地化图片 4.本地化其他文件 1.本地化应用程序名称 (1)点击"new file"然后在弹出窗口左侧选择IOS的resource项,在右侧就可以看到"String File"的图标.创建这个文件,命名

  • 解决jquery的datepicker的本地化以及Today问题

    1.本地化 可以直接加载文件,也可以直接在script后面加入如下语句 复制代码 代码如下: jQuery(function ($) { $.datepicker.regional['zh-CN'] = { closeText: '关闭', prevText: '<上月', nextText: '下月>', currentText: '今天', monthNames: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十

  • 建立自定义的数据驱动的本地化资源provider

    原文很长,为了便于阅读和理解,特将该文章改写成通俗易懂而且内容精炼的中文. 预备知识:系统默认的处理资源和本地化的方法是使用resx文件存储资源. 要使用自定义的resource provider,需要2个步骤: a) 修改web.config 文件,以便系统使用自定义的资源提供者 b) 建立自定义资源提供者类,最少包括3个: 1.ResourceProviderFactory,工厂类,用来建立ResourceProvider对象. 2.ResourceProvider,实现IResourceP

  • XML加ASP实现网页“本地化”

    想让你的站点能被来自多个国家的冲浪者看明白吗?无疑,这就需要提供多个语言版本的页面内容,也就是所谓的 "本地化"功能.最容易想到的方法就是分别编写多种语言的页面内容,然后放置到不同的目录下,再在首页上添加导航 到各自语言位置的链接.很明显,这样的处理方式将浪费许多包含公共元素以及设计框架的空间,而且修改.维护也很烦 琐.有什么好方法吗?当然,本文就介绍如何结合使用XML与ASP技术实现这个目的.  本文将讨论如下几个方面的内容:创建包含语言资源的XML文档.使用ASP创建Web页面模板

  • ASP动态网页制作技术经验分享

    学好一门编程语言有两个条件是必不可少的,一是理论与实践结合.在实际例程去验证书本上的理论能加深你对理论的理解:二是学会总结,把学习.运用中的心得体会记下来,当成一种经验或者教训加以提炼并在日后的应用中加以改进,一定能提高你对这门编程语言的认识.以下是笔者在学习与运用ASP编程中的两点经验,希望能对大家有所帮助. ASP页面内VBScript和JScript的交互 ASP具备管理不同语言脚本程序的能力,能够自动调用合适的脚本引擎以解释脚本代码和执行内置函数.ASP开发环境提供了两种脚本引擎,即VB

  • ASP.NET网页打印(只打印相关内容/自写功能)

    昨晚朋友要求在前段时间完成的新闻的网站上加上一个功能,就是在每篇新闻浏览的页面, 加一个打印铵钮.让用户一点打印,能把整篇文章打印.一开始建议朋友,叫用户使用IE浏览器的打印功能,但是朋友说,那个打印功能是把页面的不相关的内容也打印了,用户只想打印整篇文章即可. 既然要改,照做就是了.没有这方面经验,在网上找到很多相关的ASP.NET打印例子,要么太过复杂,要么效果不太理想.最后还是结合这诸多的例子,改写一个合适的功能. 下面是改写的地方,首先在文章浏览的.aspx页面,添加一个Div,并加上r

  • JS加ASP二级域名转向的代码

    自己做了asp的二级域名转向已经使用当中,但用到另一种方法:前台JS加ASP的转向程序却转不了,程序调试已经通过但不能转向不知道为什么请帮忙指出原因,谢谢!!! <% Dim whkDbq,whkSql,whkRs,whkCount Set whkConn = Server.CreateObject("ADODB.Connection") whkDbq = Server.MapPath("SqlTaoFun.mdb") whkConn.Open"Pr

  • Android中WebView加载的网页被放大的解决办法

    在某些大分辨率下,我们用WebView加载的网页可能会出现被放大的现象,这显然不是我们想要的结果,我开始看WebSettings这个是否可以设置不缩放,webSettings.setBuiltInZoomControls(false),我发现这样设置后没有任何效果,没办法只得继续看代码.后来看到有个这样的属性:WebSettings.ZoomDensity 才最终解决这个问题(网址如下:http://www.Android-doc.com/reference/android/webkit/Web

  • Android从xml加载到View对象过程解析

    我们从Activity的setContentView()入手,开始源码解析, //Activity.setContentView public void setContentView(int layoutResID) { getWindow().setContentView(layoutResID); initActionBar(); } //PhoneWindow.setContentView public void setContentView(int layoutResID) { if (

  • ASP开发网页牢记注意事项

    ASP开发网页牢记注意事项     选择自 RAINMAN_NET 的 Blog   关键字   ASP开发网页牢记注意事项  出处 永远不要相信用户输入的内容具有适当的大小或者包含适当的字符.在使用其做出决策之前应该始终对用户输入进行验证.最佳的选择是创建一个 COM+ 组件,这样您可以从 ASP 页面中调用该组件来验证用户的输入内容.您也可以使用 Server.HTMLEncode 方法.Server.URLEncode 方法,或者本页底部代码示例中的某一个.  不要通过连接用户输入的字符串

  • python+django加载静态网页模板解析

    接着前面Django入门使用示例 今天我们来看看Django是如何加载静态html的? 我们首先来看一看什么是静态HTML,什么是动态的HTML?二者有什么区别? 静态HTML指的是使用单纯的HTML或者结合CSS制作的包括图片.文字等的只供用户浏览但不包含任何脚本.不含有任何交互功能的网页! 动态的HTML指的是网页不仅提供给用户浏览,网页本身还有交互功能,存在着在脚本如JAVASCRIPT,并利用某种服务器端语言如PHP等实现如用户注册,用户登录,上传文件,下载文件等功能 接下来,了解下加载

  • 浅谈MUI框架中加载外部网页或服务器数据的方法

    我们很多同学在实施使用MUI框架的时候,在打开新的页面的时候常使用的方式是:mui.openwindow的方法,然而遇到网页需要从服务器或者是要嵌套外部的网页的时候,由于网速的问题会遇到加载时出现白屏,等待时间过长,导致用户体验不好. 页面加载的时候使用plus.webview.create方法就很好的解决了这个问题. 废话不多说直接贴代码 首先我们需要在创建一个父页面,以下是父页面的JS // H5 plus事件处理 function plusReady(){ var nwaiting = p

  • android 关于webview 加载h5网页开启定位的方法

    如下所示: //webview定位相关设置 settings.setDomStorageEnabled(true); settings.setGeolocationEnabled(true); //settings.setGeolocationDatabasePath(getFilesDir().getPath()); progressWebView.setWebChromeClient(new WebChromeClient() { @Override public void onGeoloc

随机推荐