使用XSLT將XML數(shù)據(jù)轉(zhuǎn)換成HTML_Xml教程
推薦:XML輕松學(xué)習(xí)手冊(cè)(5)XML實(shí)例解析第五章:XML實(shí)例解析 XML在不同領(lǐng)域有著廣泛的應(yīng)用,比如在科技領(lǐng)域的MathML,無(wú)線通信應(yīng)用的WML,在網(wǎng)絡(luò)圖象方面的SVG等等,我們這里側(cè)重討論XML在web上的應(yīng)用。XML在web上應(yīng)用主要是利用其
使用一個(gè)簡(jiǎn)單的 XSL 樣式表就可以將 XML 數(shù)據(jù)轉(zhuǎn)換成 HTML。隨著 XML 規(guī)范的不斷演進(jìn),在新的版本中滿足每個(gè)人的需要似乎已經(jīng)成為必要;不幸的是,進(jìn)行簡(jiǎn)單的轉(zhuǎn)換一直都困擾著規(guī)范。
假設(shè)我有一個(gè)表示一個(gè)頁(yè)面內(nèi)容的 XML 數(shù)據(jù),現(xiàn)在我想將其內(nèi)容轉(zhuǎn)換成布局。下面是我想要轉(zhuǎn)換的 XML:
<?xml version='1.0'?>
<?xml-stylesheet type="text/xsl" href="article.xsl"?>
<xml>
<folders>
<folder>
<text>Folder 1</text>
<files>
<file>
<text>File 1</text>
<fields>
<field>
<data>
<type>string</type>
<length>50</length>
<value>some data</value>
</data>
</field>
</fields>
</file>
</files>
</folder>
</folders>
</xml>
這個(gè)內(nèi)容表示一組文件夾、文件和域。每個(gè)文件夾包含文件,每個(gè)文件包含用于輸入數(shù)據(jù)的域。文件夾組中的每個(gè)文件夾都將表現(xiàn)為一個(gè) TABLE 的第一行的一個(gè) TR 元素和一個(gè) TD 元素。文件組中的每個(gè)文件都將表示為嵌套在文件夾 TR 元素中的一個(gè) TABLE 元素的第一行的一個(gè) TR 元素和一個(gè) TD 元素。域組中的每個(gè)域都將在相關(guān)的文件中表現(xiàn)為一個(gè) INPUT。
為了實(shí)現(xiàn)這一想法,我們需要將遍歷 XML 然后根據(jù)XSL 構(gòu)建一個(gè)表。
下面是用于這個(gè)轉(zhuǎn)換的 XSL:
<?xml version="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.mycompany.com/mynamespace">
<xsl:output method="html"/>
<msxsl:script language="JScript" implements-prefix="fn">
function getElementCount(nodelist, what) {
var rtrn = 0;
rtrn = nodelist[0].parentNode.selectNodes(what).length;
return (rtrn 1); //1 is added for filler TD
}
</msxsl:script>
<xsl:template match="/">
<TABLE CELLSPACING="0" CELLPADDING="0"
WIDTH="100%" BORDER="0" ID="tblRoot" NAME="tblRoot"
style="table-layout:fixed;">
<TR>
<xsl:for-each select="xml/folders/folder">
<xsl:element name="TD">
<xsl:attribute name="style">width:55px</xsl:attribute>
<xsl:value-of select="text"/>
</xsl:element>
</xsl:for-each>
<TD> </TD>
</TR>
<xsl:for-each select="xml/folders/folder">
<TR>
<xsl:element name="TD">
<xsl:attribute name="colspan">
<xsl:value-of select="fn:getElementCount(., 'folder')"/>
</xsl:attribute>
<TABLE CELLSPACING="0" CELLPADDING="0"
WIDTH="100%" BORDER="0" style="table-layout:fixed;">
<TR>
<xsl:for-each select="files/file">
<xsl:element name="TD">
<xsl:attribute name="style">width:55px;</xsl:attribute>
<xsl:value-of select="text"/>
</xsl:element>
</xsl:for-each>
<TD> </TD>
</TR>
<xsl:for-each select="files/file">
<TR>
<xsl:element name="TD">
<xsl:attribute name="colspan">
<xsl:value-of select="fn:getElementCount(., 'file')"/>
</xsl:attribute>
<xsl:for-each select="fields/field">
<xsl:element name="INPUT">
<xsl:attribute name="type">text</xsl:attribute>
<xsl:attribute name="maxlength">
<xsl:value-of select="data/length"/>
</xsl:attribute>
<xsl:attribute name="value">
&
分享:用ASP XML打造留言本一、讀者指引 讀者指引幫助你掌握本文的梗概。以免你看了大半才明白這編文章不適合你,給你造成視覺(jué)污染。 如果你正在用ASP XML寫(xiě)一些程序,或者你正在學(xué)XML那就值得一看。 閱讀
- xml創(chuàng)建節(jié)點(diǎn)(根節(jié)點(diǎn)、子節(jié)點(diǎn))
- WML開(kāi)發(fā)教程之 WAP網(wǎng)站服務(wù)器配置方法
- WMLScript的語(yǔ)法基礎(chǔ)
- 收集的WML Script標(biāo)準(zhǔn)函數(shù)庫(kù)
- WML教程之文本框控件Input
- 無(wú)線標(biāo)記語(yǔ)言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)
- xml文件的結(jié)構(gòu)解讀
- 關(guān)于XSL - XSL教程
- 選擇模式 - XSL教程 - 2
- XPath入門 - XSL教程 - 3
- 匹配模式 - XSL教程 - 4
- 測(cè)試模式 - XSL教程 - 5
Xml教程Rss訂閱編程教程搜索
Xml教程推薦
猜你也喜歡看這些
- 使用PHP和AJAX的XML編程(4)
- 解析xslt的簡(jiǎn)單使用[xml-->html]
- UTF8轉(zhuǎn)成GB2312亂碼問(wèn)題解決方案
- 如何建立一個(gè) XML 的開(kāi)發(fā)環(huán)境
- javascript調(diào)用XML制作連動(dòng)下拉框
- XML卷之實(shí)戰(zhàn)錦囊(5):結(jié)構(gòu)樹(shù)圖
- XML輕松學(xué)習(xí)手冊(cè)(2)XML概念
- 詳解XML WebService
- 用Asp與XML實(shí)現(xiàn)交互的一個(gè)實(shí)例源碼
- 解析XML輕松學(xué)習(xí)手冊(cè)(3)XML的術(shù)語(yǔ)
- 相關(guān)鏈接:
- 教程說(shuō)明:
Xml教程-使用XSLT將XML數(shù)據(jù)轉(zhuǎn)換成HTML。