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

首頁 > 開發 > XML > 正文

將XML數據轉換成HTM

2024-09-05 20:55:28
字體:
來源:轉載
供稿:網友
使用一個簡單的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 規范的信息。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美午夜无遮挡| 久久久人成影片一区二区三区| 日韩电影免费在线观看| 韩国三级日本三级少妇99| 另类天堂视频在线观看| 欧美亚洲日本网站| 青青草原一区二区| 日韩国产高清视频在线| 狠狠综合久久av一区二区小说| 91精品视频免费观看| 久久99精品国产99久久6尤物| 欧美疯狂做受xxxx高潮| 久久黄色av网站| 91日本视频在线| 欧美成年人在线观看| 亚洲性生活视频在线观看| 久久久久亚洲精品国产| 欧美精品电影在线| 久久天堂av综合合色| 成人中文字幕在线观看| 亚洲日韩欧美视频| 国产成人精品在线观看| 亚洲男人的天堂在线播放| 欧美在线观看一区二区三区| 亚洲第一偷拍网| 欧美野外猛男的大粗鳮| 久久久精品网站| 性色av一区二区三区在线观看| 久久九九免费视频| 欧美成人精品在线播放| 欧美wwwxxxx| 亚洲人午夜精品免费| 69久久夜色精品国产69| 成人乱人伦精品视频在线观看| 91久久久亚洲精品| 国语自产精品视频在线看一大j8| www.日韩免费| 日韩av免费看| 国产日本欧美一区二区三区| 欧美国产日韩免费| 国产一区视频在线播放| 日韩激情片免费| 色综合色综合网色综合| 久久免费精品视频| 日韩人体视频一二区| 成人av.网址在线网站| 色悠悠久久久久| 国产精品久久91| 国产999视频| 国产精品一区二区三区久久| 欧美猛交ⅹxxx乱大交视频| 亚洲深夜福利网站| 国产不卡av在线免费观看| 亚洲国产精品女人久久久| 亚洲a在线播放| 欧美在线播放视频| 伊人男人综合视频网| 91成人精品网站| 第一福利永久视频精品| 北条麻妃99精品青青久久| 日韩大陆欧美高清视频区| 中文字幕精品久久久久| 亚洲区一区二区| 国产精品午夜一区二区欲梦| 国产精品吹潮在线观看| 成人a在线观看| 欧美成人免费在线视频| 日韩av中文字幕在线播放| 国产精品久久久久久久一区探花| www国产亚洲精品久久网站| 国内精品中文字幕| 91在线免费观看网站| 亚洲人成电影在线观看天堂色| 精品国产依人香蕉在线精品| 91网站在线免费观看| 国产精品爽黄69天堂a| 色老头一区二区三区在线观看| 欧美另类高清videos| 国产一区二区视频在线观看| 国产精品久久二区| 亚洲一区二区久久久久久久| 国产精品日日摸夜夜添夜夜av| 欧美精品精品精品精品免费| 在线亚洲午夜片av大片| 亚洲3p在线观看| 狠狠躁天天躁日日躁欧美| 国产精品视频在线播放| 国产精品影片在线观看| 在线观看中文字幕亚洲| 国产乱肥老妇国产一区二| 精品久久久久久亚洲精品| 欧美有码在线视频| 色婷婷久久av| 亚洲国产美女精品久久久久∴| 中文字幕亚洲欧美日韩2019| 91免费高清视频| 亚洲人成网站777色婷婷| 日韩最新中文字幕电影免费看| 日本aⅴ大伊香蕉精品视频| 国产精品美乳在线观看| 在线观看国产成人av片| 亚洲自拍偷拍色片视频| 亚洲аv电影天堂网| 日韩av影院在线观看| 久久久影视精品| 国内精品久久影院| 日韩av在线网站| 国产成人一区二区三区小说| 亚洲图中文字幕| 日韩av网址在线| 亚洲福利视频在线| 色综合影院在线| 久久影视电视剧免费网站清宫辞电视| 川上优av一区二区线观看| 清纯唯美亚洲综合| 久久中文字幕国产| 亚洲成人av在线播放| 成人精品一区二区三区| 91精品国产高清久久久久久| 久久久久九九九九| 久久久国产精品免费| 日韩精品视频三区| 欧美视频免费在线| 亚洲毛茸茸少妇高潮呻吟| 欧美日韩国产一区二区| 日本最新高清不卡中文字幕| 奇米成人av国产一区二区三区| 狠狠躁夜夜躁人人躁婷婷91| 精品视频在线观看日韩| 国产欧美欧洲在线观看| 国产亚洲美女精品久久久| 国产成人亚洲综合青青| 久久久久久久久久久网站| 国产a∨精品一区二区三区不卡| 国产丝袜一区视频在线观看| 欧美电影在线观看高清| 最新69国产成人精品视频免费| 国产午夜精品全部视频播放| 国产成人福利网站| 97在线视频一区| 国产精品99免视看9| 欧美巨猛xxxx猛交黑人97人| 成人国产精品日本在线| 日韩欧美国产一区二区| 狠狠躁夜夜躁人人爽天天天天97| 欧美壮男野外gaytube| www国产亚洲精品久久网站| 亚洲国产天堂网精品网站| 中文字幕亚洲综合| 久精品免费视频| 亚洲一区二区三区在线免费观看| 欧美电影《睫毛膏》| 亚洲精品不卡在线| 亚洲国产精品一区二区久| 韩曰欧美视频免费观看| 久久精品国产2020观看福利| 一区二区三区美女xx视频| 日韩欧美精品网址| 国产精品日韩在线播放| 欧美日韩成人在线观看| 国产精品男女猛烈高潮激情| 中文字幕亚洲无线码a| 亚洲精品国产综合区久久久久久久| 成人女保姆的销魂服务|