如何使用XSL和ASP在线编辑XML文档
这篇文章主要介绍了如何使用XSL和ASP在线编辑XML文档,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
本文通过一个详细的例子,来阐述了在线编辑XML文档数据的方法。由于Netscape对XML的支持比较弱,因此,要实现跨平台的数据交换,数据的处理必须在服务器端进行。要编辑XML文档,首先要做的事情就是怎样把这些数据提取并显示给访问者,XSL为我们显示XML文件提供了一个很好的解决方案。下面的例子就是利用XSL样式单把XML文档显示出来,供用户进行编辑,然后再把编辑后的数据提交到服务器,在服务器端进行数据的http://www.php.cn/php/php-tp-renewal.html" target="_blank">更新。这里采用ASP(Active Server Pages)来完成我们的任务。
首先,载入我们要进行编辑的XML文档,利用微软的文档对象模型(Microsoft XMLDOM Object)和XSL,XML文档就可以在服务器端转换成可以在客户端显示的HTML文件内容。下面先看看我们使用的XML和XSL文件是什么样子的。
XML文件:userdata.xml
<?xmlversion="1.0"encoding="gb2312"?> <用户资料> <fieldid="姓名"taborder="1"> <field_value>孟子</field_value> </field> <fieldid="性别"taborder="2"> <field_value>男</field_value> </field> <fieldid="单位名称"taborder="3"> <field_value>中国网络技术发展公司北京分公司</field_value> </field> <fieldid="详细地址"taborder="4"> <field_value>北京市嘉里中心102层</field_value> </field> <fieldid="电话"taborder="5"> <field_value>1391139136*</field_value> </field> <fieldid="电子邮件"taborder="6"> <field_value>amxh@21cn.com</field_value> </field> </用户资料> XSL文件:userdata.xsl <?xmlversion="1.0"encoding="gb2312"?> <xsl:stylesheetxmlns:xsl="http://www.w3.org/TR/WD-xsl"> <xsl:templatematch="/"> <html> <metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/> <body> <formmethod="post"action="Edituserdata.asp"> <h2>用户资料编辑:</h2> <tableborder="1"cellpadding="2"> <xsl:for-eachselect="用户资料/field"> <tr> <td> <xsl:value-ofselect="@id"/> </td> <td> <inputtype="text"><xsl:attributename="id"><xsl:value-ofselect="@id"/> </xsl:attribute><xsl:attributename="name"><xsl:value-ofselect="@id"/> </xsl:attribute><xsl:attributename="value"><xsl:value-ofselect="field_value"/> </xsl:attribute></input> </td> </tr> </xsl:for-each> </table> <br/> <inputtype="submit"id="btnSubmit"name="btnSubmit"value="完成编辑"/> </form> </body> </html> </xsl:template> </xsl:stylesheet>
XSL文件使用了XSL:for-each元素的来遍历整个XML文件,XML文件里每个“field”元素的“id”属性和HTML表单的文本输入框的“id”和“name”想对应。这样,HTML表单的文本输入框就显示出了XML文件的元素值。此文件负责XML文档在服务器端的转换,以便能在各种浏览器上显示。
下面是关键的程序,它实现打开和更新XML文档的功能,并根据表单的提交与否,来决定是否进行更新。它包含了两个函数,loadXMLFile负责载入和转换要显示的XML文件;updateXML函数负责更新XML文件。
Edituserdata.asp程序如下:
<% '----------------------------------------------------------- '定义函数loadXMLFile(),接收二个参数: 'strXMLFile-XML文件的路径和文件名字 'strXSLFilee-XSL文件的路径和文件名字 '----------------------------------------------------------- FunctionloadXMLFile(strXMLFile,strXSLFile) 'Declarelocalvariables DimobjXML DimobjXSL '实例化XMLDOM对象,以便载入XML文件。 setobjXML=Server.CreateObject("Microsoft.XMLDOM") '关掉文件异步载入模式。 objXML.async=false '载入XML文件! objXML.load(strXMLFile) '实例化XMLDOM对象,以便载入XSL文件。 setobjXSL=Server.CreateObject("Microsoft.XMLDOM") '关掉文件异步载入模式。 objXSL.async=false '载入XSL文件! objXSL.load(strXSLFile) '利用XMLDOM的transformNode方法,把XSL样式表应用到XML文档,然后输出到客户端。 Response.Write(objXML.transformNode(objXSL)) EndFunction '------------------------------------------------------------------ '函数updateXML()接收一个参数:strXMLFile-XML文件的路径和文件名。 '------------------------------------------------------------------ FunctionupdateXML(strXMLFile) '声明局部变量。 DimobjDom DimobjRoot DimobjField Dimx '实例化XMLDOM对象。 setobjDOM=Server.CreateObject("Microsoft.XMLDOM") '关掉文件异步载入模式。 objDOM.async=false '载入XML文件。 objDOM.loadstrXMLFile '设定根元素。 SetobjRoot=objDom.documentElement '遍历FORM集合,并把提交的数据写入XML文件。 Forx=1toRequest.Form.Count '检查提交的数据是否包含按钮。如果是,忽略此数据。 Ifinstr(1,Request.Form.Key(x),"btn")=0Then '按照XSL查询模式,建立objField变量,把表单的元素对应到XML文档里的相应元素[field_value]。 SetobjField=objRoot.selectSingleNode("field[@id='"&Request.Form.Key(x)&"']/field_value") '把表单提交的数据和XML文档里的节点值对应起来。 objField.Text=Request.Form(x) EndIf Next '保存编辑过的XML文件。 objDom.savestrXMLFile '释放所有对对象的引用。 SetobjDom=Nothing SetobjRoot=Nothing SetobjField=Nothing '调用loadXMLFile函数,把新编辑后的XML文件用updateduserdata.xsl样式单显示到客户端。 loadXMLFilestrXMLFile,server.MapPath("updateduserdata.xsl") EndFunction '检查表单是否成功提交,如提交,更新XML文件;否则,转到编辑状态。 IfRequest.Form("btnSubmit")=""Then loadXMLFileserver.MapPath("userdata.xml"),server.MapPath("userdata.xsl") Else updateXMLserver.MapPath("userdata.xml") EndIf %>
当表单提交成功后,我们用updateduserdata.xsl来显示我们刚刚编辑的数据。
updateduserdata.xsl如下:
<?xmlversion="1.0"encoding="gb2312"?> <xsl:stylesheetxmlns:xsl="http://www.w3.org/TR/WD-xsl"> <xsl:templatematch="/"> <html> <metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/> <body> <h2>更新后的用户资料如下:</h2> <tableborder="1"cellpadding="2"> <xsl:for-eachselect="用户资料/field"> <tr> <td> <xsl:value-ofselect="@id"/> </td> <td> <xsl:value-ofselect="field_value"/> </td> </tr> </xsl:for-each> </table> <form> <inputtype="button"value="返回"onclick="history.go(-1)"/> </form> </body> </html> </xsl:template> </xsl:stylesheet>
感谢你能够认真阅读完这篇文章,希望小编分享的“如何使用XSL和ASP在线编辑XML文档”这篇文章对大家有帮助,同时也希望大家多多支持恰卡编程网,关注恰卡编程网行业资讯频道,更多相关知识等着你来学习!
推荐阅读
-
Web应用从零开始,初学者友好型开发教程
-
容器化最佳实践:Docker 与 Kubernetes 在微服务架构中的协同设计
-
AWS Cloud9 使用攻略:云端 IDE 如何无缝集成 Lambda 与 S3 服务?
-
Heroku vs AWS Elastic Beanstalk:快速部署 Web 应用的平台对比
-
Kubernetes 集群部署避坑:资源调度、服务发现与滚动更新策略
-
Docker 镜像优化指南:分层构建、瘦身技巧与多阶段编译实践
-
Postman 接口测试全流程:从 API 设计到自动化测试脚本编写
-
pytest 框架进阶:自定义 fixture、插件开发与持续集成集成方案
-
JUnit 5 新特性:参数化测试、扩展模型与微服务测试实践
-
Chrome DevTools 性能分析:FPS 监控、内存快照与网络请求优化指南