亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > ASP > 正文

利用XSL和ASP實現XML文檔在線編輯

2024-05-04 11:06:46
字體:
來源:轉載
供稿:網友

本文通過一個詳細的例子,來闡述了在線編輯XML文檔數據的方法。由于Netscape對XML的支持比較弱,因此,要實現跨平臺的數據交換,數據的處理必須在服務器端進行。要編輯XML文檔,首先要做的事情就是怎樣把這些數據提取并顯示給訪問者,XSL為我們顯示XML文件提供了一個很好的解決方案。下面的例子就是利用XSL樣式單把XML文檔顯示出來,供用戶進行編輯,然后再把編輯后的數據提交到服務器,在服務器端進行數據的更新。這里采用ASP(Active Server Pages)來完成我們的任務。

  首先,載入我們要進行編輯的XML文檔,利用微軟的文檔對象模型(Microsoft XMLDOM Object)和XSL,XML文檔就可以在服務器端轉換成可以在客戶端顯示的HTML文件內容。下面先看看我們使用的XML和XSL文件是什么樣子的。

  XML文件:UserData.xml

<?xml version="1.0" encoding="gb2312"?> 
<!-- edited with XMLSPY v2004 rel. 4 U (http://www.xmlspy.com) by Dicky (Apple'S Eden) --> 
?。糢serInfo> 
  <Field ID="Name" TabOrder="1"> 
  ?。糉ieldValue>Dicky</FieldValue> 
  </Field> 
 ?。糉ield ID="Sex" TabOrder="2"> 
  ?。糉ieldValue>Male</FieldValue> 
 ?。?Field> 
 ?。糉ield ID="UnitName" TabOrder="3"> 
  ?。糉ieldValue>ShangHai Ateam Company</FieldValue> 
  </Field> 
 ?。糉ield ID="Address" TabOrder="4"> 
  ?。糉ieldValue>ShangHai,ZhongShan West Road 1800#,Room 26A</FieldValue> 
 ?。?Field> 
  <Field ID="Tel" TabOrder="5"> 
  ?。糉ieldValue>13800138000</FieldValue> 
  </Field> 
  <Field ID="EMail" TabOrder="6"> 
  ?。糉ieldValue>AppleBBS@GMail.Com</FieldValue> 
 ?。?Field> 
</UserInfo>

  XSL文件:UserData.xsl

<?xml version="1.0" encoding="gb2312"?> 
<!-- edited with XMLSPY v2004 rel. 4 U (http://www.xmlspy.com) by Dicky (Apple'S Eden) --> 
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl"> 
<xsl:template match="/"> 
<html> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"/> 
<body> 
 <form method="post" action="EditUserData.asp"> 
 ?。糷1>Edit UserInfo:</h1> 
  <table border="1" cellpadding="2"> 
 ?。紉sl:for-each select="UserInfo/Field"> 
  <tr> 
  ?。紅d> 
   ?。紉sl:value-of select="@ID"/> 
   </td> 
  ?。紅d> 
    <input type="text"> 
    ?。紉sl:attribute name="ID"><xsl:value-of select="@ID"/></xsl:attribute> 
     <xsl:attribute name="Name"><xsl:value-of select="@ID"/></xsl:attribute> 
    ?。紉sl:attribute name="Value"><xsl:value-of select="FieldValue"/></xsl:attribute> 
    </input> 
  ?。?td> 
 ?。?tr> 
  </xsl:for-each> 
 ?。?table> 
  <br/> 
 ?。糹nput type="submit" id="btnSubmit" name="btnSubmit" value="Edit"/>
 </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 文件的路徑和文件名字 
 '----------------------------------------------------------- 
Function LoadXMLFile(strXMLFile, strXSLFile) 
 'Declare local variables 
 Dim objXML 
 Dim objXSL 
 '實例化 XMLDOM 對象,以便載入 XML 文件。 
 Set objXML = Server.CreateObject("Microsoft.XMLDOM") 
 '關掉文件異步載入模式。 
 objXML.Async = False 
 '載入 XML 文件! 
 objXML.Load(strXMLFile) 
 '實例化 XMLDOM 對象,以便載入 XSL 文件。 
 Set objXSL = Server.CreateObject("Microsoft.XMLDOM") 
 '關掉文件異步載入模式。 
 objXSL.Async = False 
 '載入 XSL 文件! 
 objXSL.Load(strXSLFile) 
 '利用 XMLDOM 的 transformNode 方法,把 XSL 樣式表應用到 XML 文檔,然后輸出到客戶端。 
 Response.Write(objXML.TransFormNode(objXSL)) 
End Function
'------------------------------------------------------------------ 
'函數 updateXML() 接收一個參數:strXMLFile - XML 文件的路徑和文件名。 
'------------------------------------------------------------------ 
Function UpdateXML(strXMLFile) 
 '聲明局部變量。 
 Dim objDom 
 Dim objRoot 
 Dim objField 
 Dim x 
 '實例化 XMLDOM 對象。 
 Set objDOM = Server.CreateObject("Microsoft.XMLDOM") 
 '關掉文件異步載入模式。 
 objDom.Async = False 
 '載入 XML 文件。 
 objDom.Load strXMLFile 
 '設定根元素。 
 Set objRoot = objDom.DocumentElement 
 '遍歷 FORM 集合,并把提交的數據寫入 XML 文件。 
 For x = 1 To Request.Form.Count 
  '檢查提交的數據是否包含按鈕。如果是,忽略此數據。 
  If Instr(1,Request.Form.Key(x),"btn") = 0 Then 
   '按照 XSL 查詢模式,建立 objField 變量,把表單的元素對應到 XML 文檔里的相應元素[field_value]。 
   Set objField = objRoot.SelectSingleNode("Field[@ID='" & Request.Form.Key(x) & "']/FieldValue") 
   '把表單提交的數據和 XML 文檔里的節點值對應起來。 
   objField.Text = Request.Form(x) 
  End If 
 Next 
 '保存編輯過的 XML 文件。 
 objDom.Save strXMLFile 
 '釋放所有對對象的引用。 
 Set objDom = Nothing 
 Set objRoot = Nothing 
 Set objField = Nothing 
 '調用 LoadXMLFile 函數,把新編輯后的 XML 文件用 UpdatedUserData.xsl 樣式單顯示到客戶端。 
 LoadXMLFile strXMLFile,Server.MapPath("UpdatedUserData.xsl") 
End Function

'檢查表單是否成功提交,如提交,更新 XML 文件;否則,轉到編輯狀態。

If Request.Form("btnSubmit") = "" Then 
 LoadXMLFile Server.MapPath("UserData.xml"),Server.MapPath("UserData.xsl") 
Else 
 UpdateXML Server.MapPath("UserData.xml") 
End If 
%>

  當表單提交成功后,我們用UpdatedUserData.xsl來顯示我們剛剛編輯的數據。

  UpdatedUserData.xsl如下:

 程序代碼

<?xml version="1.0" encoding="gb2312"?> 
<!-- edited with XMLSPY v2004 rel. 4 U (http://www.xmlspy.com) by Dicky (Apple'S Eden) --> 
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl"> 
<xsl:template match="/"> 
<html> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"/> 
<body> 
<h1>Updated UserInfo:</h1> 
<table border="1" cellpadding="2"> 
?。紉sl:for-each select="UserInfo/Field"> 
?。紅r> 
 ?。紅d> 
   <xsl:value-of select="@ID"/> 
 ?。?td> 
 ?。紅d> 
   <xsl:value-of select="FieldValue"/> 
 ?。?td> 
 </tr> 
?。?xsl:for-each> 
</table> 
<form> 
<input type="button" value="Go Back" onclick="history.go(-1)"/> 
</form> 
</body> 
</html> 
</xsl:template> 
</xsl:stylesheet>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
伊人久久免费视频| 亚洲香蕉成人av网站在线观看| 国产99久久精品一区二区| 亚洲激情视频网站| 精品福利在线视频| www.久久色.com| 亚洲美女动态图120秒| 亚洲国产女人aaa毛片在线| www.久久撸.com| 国产成人+综合亚洲+天堂| 亚洲人高潮女人毛茸茸| 国产成人拍精品视频午夜网站| 深夜精品寂寞黄网站在线观看| 成人伊人精品色xxxx视频| 欧美黄网免费在线观看| 亚洲精品国产美女| 亚洲人成绝费网站色www| 久久人人爽国产| 2018中文字幕一区二区三区| 国产精品一区二区在线| 久久99热这里只有精品国产| 中文字幕精品久久久久| 久久影视免费观看| 亚洲精品成人久久| 亚洲一区二区在线播放| 北条麻妃一区二区三区中文字幕| 国产成人精品av| 欧美午夜www高清视频| 社区色欧美激情 | 亚洲人成电影在线观看天堂色| 亚洲品质视频自拍网| 欧美激情一区二区三区高清视频| 欧美激情在线一区| 97在线观看免费| 亚洲欧洲一区二区三区久久| 91久久夜色精品国产网站| 亚洲激情第一页| 久精品免费视频| 国a精品视频大全| 日本欧美在线视频| 日韩av免费一区| 在线电影欧美日韩一区二区私密| 在线观看欧美视频| 国产精品久久久久秋霞鲁丝| 一区二区三区黄色| 欧美性猛交xxxx乱大交| 日本成人黄色片| 日本高清久久天堂| 日韩黄色高清视频| 97在线观看视频国产| 国产成人高潮免费观看精品| 国产精品入口夜色视频大尺度| 国产香蕉97碰碰久久人人| 久热精品在线视频| 精品视频中文字幕| 亚洲色图第一页| 亚洲精品av在线播放| 91国产美女在线观看| 欧美日韩亚洲一区二区| 欧美福利在线观看| 91精品免费看| 成人福利网站在线观看11| 日韩在线观看免费全| 亚洲午夜精品久久久久久久久久久久| 日本久久久久亚洲中字幕| 在线看国产精品| 精品久久久国产精品999| 成人黄色av网站| 91色在线观看| 久久亚洲精品毛片| 精品国产91乱高清在线观看| 中文字幕亚洲精品| 欧美与欧洲交xxxx免费观看| 国产日韩欧美夫妻视频在线观看| 国产精品v片在线观看不卡| 成人h视频在线观看播放| 啪一啪鲁一鲁2019在线视频| 亚洲国产成人在线播放| 成人av在线天堂| 久久精品国产久精国产思思| 日韩免费在线电影| 欧美日韩国内自拍| 日韩欧美国产成人| 欧美中文字幕视频在线观看| 欧美日韩国产在线| 亚洲国产精品专区久久| 久久久影视精品| 欧美高清电影在线看| 欧美在线亚洲在线| 国产精品嫩草影院一区二区| 欧美性猛交xxxx久久久| 久久人人97超碰精品888| 欧美激情2020午夜免费观看| 欧美亚洲视频一区二区| 国产成人免费91av在线| 久久成人18免费网站| 最好看的2019年中文视频| 久久精品91久久久久久再现| 日韩高清免费在线| 国产97在线视频| 国产在线播放91| 91地址最新发布| 亚洲无限乱码一二三四麻| 国产精品wwwwww| 欧美午夜性色大片在线观看| 亚洲影影院av| 久久久电影免费观看完整版| 4p变态网欧美系列| 91夜夜揉人人捏人人添红杏| 欧美成年人网站| 疯狂欧美牲乱大交777| 国产色婷婷国产综合在线理论片a| 久久久久国产精品免费| 91久久在线播放| 国产日韩欧美电影在线观看| 亚洲成人a级网| 国产精品亚洲欧美导航| 亚洲深夜福利在线| 黄色精品一区二区| 欧美亚洲国产日本| 国产精品第1页| 在线成人激情视频| 亚州精品天堂中文字幕| 5566成人精品视频免费| 久久欧美在线电影| 成人日韩在线电影| 91久久夜色精品国产网站| 38少妇精品导航| 亚洲级视频在线观看免费1级| 日韩电影免费观看在线| 中文字幕久久久av一区| 日本精品久久久久久久| 日韩精品一区二区视频| 欧美激情videos| 这里只有精品视频| 欧美日韩中文字幕综合视频| 91精品国产91久久久| 国产欧美日韩视频| 日韩电影网在线| 亚洲精品视频网上网址在线观看| 亚洲一区二区中文字幕| 日韩黄在线观看| 久久久久久国产精品美女| 欧美孕妇孕交黑巨大网站| 亚洲人成网站色ww在线| 俺去啦;欧美日韩| 成人精品久久av网站| 91精品久久久久久久久久久久久| 国产精彩精品视频| 欧美一级视频在线观看| 日本精品久久久久久久| 日韩视频在线免费| 久久久久久999| 欧美成人精品在线观看| 国产在线观看精品一区二区三区| 国产丝袜精品第一页| 97成人超碰免| 国产精品自产拍高潮在线观看| 欧美精品videossex性护士| 亚洲天堂影视av| 一本色道久久88精品综合| 欧美精品电影免费在线观看| 亚洲毛片在线免费观看| 国产精品白丝jk喷水视频一区|