首頁  >  文章  >  後端開發  >  詳細介紹將XML資料轉換成HTML的範例程式碼

詳細介紹將XML資料轉換成HTML的範例程式碼

黄舟
黄舟原創
2017-03-11 17:35:312104瀏覽

使用一個簡單的XSL樣式表就可以將XML資料轉換成HTML。隨著XML規範的不斷演進,在新的版本中滿足每個人的需要似乎已經成為必要;假設有一個表示一個頁面內容的XML數據,現在想將其內容轉換​​成佈局。下面是想要轉換的XML: 

85fa80ee361e700c2be4d997bc9733c9 
31fe81e98afd17e4b9a8a28bedee1cf1 
b2a0af5a8fd26276da50279a1c63a57a 
254d0476a3bbaede07403c5f35da3e25 
59ef88518edd60e9f6a2c9f2c966ac0c 
28f128881ce1cdc57a572953e91f7d0fFolder1273e21371c5d5e701d3c98517a0bfa41 
c6a235960c38d509b87ca752283a5cb2 
28897b20adb25fbae118a3f80f538dec 
28f128881ce1cdc57a572953e91f7d0fFile1273e21371c5d5e701d3c98517a0bfa41 
5d31de15119673d8345a6e7e4e3539c8 
d737d0a06790df603d79bb2c76c86712 
1d029f6197b5a3eb8a3fdf0a088ddf55 
7674b22ef33c73b930516fd6bc30b7a3string47da3aec5fea7de36e415e6398f16561 
d82af2074b26fcfe177e947839b5d381500a47fdba4028b9e1b40fb76257dcf69f 
8487820b627113dd990f63dd2ef215f3somedata4b175f9a50d57c75316becd702e959dc 
07b4fdd0136efc154b4b9d48cfcbbb9d 
6d2ce49320ba9a8e638019ef6c9bc2ef 
7e3a30f0b0961b04563491c9888611a7 
a83812d91bc3e67c6d4248fcc5008811 
917d3984ce33e8bdef33749ba625760b 
506346dddbef7ce31b7ff0aa13ddacdf 
c1a7601f3a9fa679b3cd6fdf4f6dbe8d 
21118965b89073f60271ef4a3b5d3c58

 這個內容表示一組資料夾、檔案和網域。每個資料夾包含檔案,每個檔案包含用於輸入資料的網域。資料夾組中的每個資料夾都會表現為一個 TABLE 的第一行的一個 TR 元素和一個 TD 元素。檔案組中的每個檔案都會表示為嵌套在資料夾 TR 元素中的一個 TABLE 元素的第一行的一個 TR 元素和一個 TD 元素。域組中的每個域都將在相關的文件中表現為一個 INPUT。
下面是用於這個轉換的XSL: 

<?xmlversion="1.0"?> 
<xsl:stylesheet 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"version="1.0" 
xmlns:msxsl="urn:schemas-microsoft-com:xslt" 
xmlns:fn=http://www.aaa.com/aaa> 
<xsl:outputmethod="html"/> 
<msxsl:scriptlanguage="JScript"implements-prefix="fn"> 
functiongetElementCount(nodelist,what){ 
varrtrn=0; 
rtrn=nodelist[0].parentNode.selectNodes(what).length; 
return(rtrn 1);//1isaddedforfillerTD 
} 
</msxsl:script> 
<xsl:templatematch="/"> 
<TABLECELLSPACING="0"CELLPADDING="0" 
WIDTH="100%"BORDER="0"ID="tblRoot"NAME="tblRoot" 
style="table-layout:fixed;"> 
<TR> 
<xsl:for-eachselect="xml/folders/folder"> 
<xsl:elementname="TD"> 
<xsl:attributename="style">width:55px</xsl:attribute> 
<xsl:value-ofselect="text"/> 
</xsl:element> 
</xsl:for-each> 
<TD></TD> 
</TR> 
<xsl:for-eachselect="xml/folders/folder"> 
<TR> 
<xsl:elementname="TD"> 
<xsl:attributename="colspan"> 
<xsl:value-ofselect="fn:getElementCount(.,&#39;folder&#39;)"/> 
</xsl:attribute> 

<TABLECELLSPACING="0"CELLPADDING="0" 
WIDTH="100%"BORDER="0"style="table-layout:fixed;"> 
<TR> 
<xsl:for-eachselect="files/file"> 
<xsl:elementname="TD"> 
<xsl:attributename="style">width:55px;</xsl:attribute> 
<xsl:value-ofselect="text"/> 
</xsl:element> 
</xsl:for-each> 
<TD></TD> 
</TR> 
<xsl:for-eachselect="files/file"> 
<TR> 
<xsl:elementname="TD"> 
<xsl:attributename="colspan"> 
<xsl:value-ofselect="fn:getElementCount(.,&#39;file&#39;)"/> 
</xsl:attribute> 
<xsl:for-eachselect="fields/field"> 
<xsl:elementname="INPUT"> 
<xsl:attributename="type">text</xsl:attribute> 
<xsl:attributename="maxlength"> 
<xsl:value-ofselect="data/length"/> 
</xsl:attribute> 
<xsl:attributename="value"> 
<xsl:value-ofselect="data/value"/> 
</xsl:attribute> 
</xsl:element><BR/> 
</xsl:for-each> 
</xsl:element> 
</TR> 
</xsl:for-each> 
</TABLE> 
</xsl:element> 
</TR> 
</xsl:for-each> 
</TABLE> 
</xsl:template> 
</xsl:stylesheet>

# 在stylesheet 標記中,設定了幾個命名空間,包括定義所有xsl 轉換標記的xsl 命名空間。能夠讓我們建立可以在樣式表中使用的使用者函數的msxml 命名空間。使用它來得到所有的子元素,以便得到一個 TD 標記的 COLSPAN 屬性集。用於加入一組使用者定義的函數的fn 命名空間,該命名空間由msxml:script element 建立。 
 然後,我們建立外部 TABLE 和第一個 TR。在 TR 中,為 XML 中指定的每個資料夾建立一個 TD。使用了 xsl:element 標記,因為它允許新增自訂屬性或執行函數來為另一個 TD 元素中的 COLSPAN 屬性設定一個屬性。 
 在為每個資料夾建立了所需的 TD 之後,開始為每個資料夾建立 TR。只在這個TR 新增一個 TD,但是將它的 COLSPAN 屬性設為等於資料夾群組中資料夾標記的數量再加一。多出的一是用來在一個固定佈局樣式的 TABLE 中填入空格用的。 
 為了得到 COLSPAN,傳入目前的脈絡(在這裡由「.」指定)和計算的節點的名字。在函數中,得到目前的上下文,paraentNode,和 XPath 查詢中指定的節點的數量。然後函數傳回這個數量加上一個以填充 TD。 
 有了這個 TD,在其中嵌入另一個 TABLE,該 TABLE 包含檔案群組中的每個檔案。從這一點開始,其流程就與外部 TABLE 轉換一樣。最後的步驟是新增每個文件中的網域。
 一旦完成了通用佈局,就可以開始新增使用者介面功能了,比如說隱藏掉其它的資料夾和檔案行,直到使用者點擊了相關的選項卡。這項功能可以透過編寫支援此功能的腳本來實現,新增一個 onclick xsl:attribute 元素到資料夾和檔案 TD 元素,然後將它的值設為腳本函數的名字。 
 最後,在通用功能完成之後,你可以加入class xsl:attributes 並在 STYLE 或 CSS 中加入相關的classNames 得到你想要的外觀。 
 這個範例為部署 Web 資料解決方案中使用到的 File-Folder-Field 檢視建立了一個基礎。存取 MSDN 找到更多有關Microsoft 的 XML 規範的資訊。

以上是詳細介紹將XML資料轉換成HTML的範例程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn