使用一個簡單的XSL樣式表就可以將XML資料轉換成HTML。隨著XML規範的不斷演進,在新的版本中滿足每個人的需要似乎已經成為必要;假設有一個表示一個頁面內容的XML數據,現在想將其內容轉換成佈局。下面是想要轉換的XML:
<?xmlversion='1.0'?> <?xml-stylesheettype="text/xsl"href="article.xsl"?> <xml> <folders> <folder> <text>Folder1</text> <files> <file> <text>File1</text> <fields> <field> <data> <type>string</type> <length>50</length> <value>somedata</value> </data> </field> </fields> </file> </files> </folder> </folders> </xml>
這個內容表示一組資料夾、檔案和網域。每個資料夾包含檔案,每個檔案包含用於輸入資料的網域。資料夾組中的每個資料夾都會表現為一個 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(.,'folder')"/> </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(.,'file')"/> </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中文網其他相關文章!