国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 開發 > 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 規范的信息。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
在线观看国产福利视频| 国产一级粉嫩xxxx| 丁香视频五月| 国产黄视频网站| 精品无人区乱码1区2区3区免费| 国产嫩草在线视频| 国产成人va亚洲电影| 精品176二区| 97一区二区三区| 在线视频中文字幕| 青青草原国产在线观看| 国产毛片在线看| 18成年在线观看| 久久99国产视频| 国产黄色免费网| 男女羞羞视频在线观看| 国产91在线视频蝌蚪| 精品av中文字幕在线毛片| 中文日本在线观看| 成人免费一区二区三区视频网站| 国产人成在线观看| 欧美国产中文| 国产不卡在线| 福利在线视频导航| 日本视频一二三区中文字幕| 中文字幕高清av| 国产视频精选在线| 开心婷婷激情五月| www.色婷婷| 亚洲成a人v欧美综合天堂麻豆| 性色视频在线| www.夜夜操.com| 中文字幕高清av| 丁香花高清在线观看完整版| 四虎久久影院| 亚洲视频在线观看不卡| 国产l精品国产亚洲区在线观看| 国产麻豆综合视频在线观看| 日本福利在线观看| sese在线视频| 久久国产精品久久久久久小说| av免费网站在线观看| 91麻豆免费在线视频| 国产三级在线免费| 国产传媒在线播放| 国产精品黄页网站在线播放免费| 国产精品久久在线| 91精品大全| 一本免费视频| 牛牛精品视频在线| 国产乱视频在线观看| 五月婷婷在线观看| 国产一级在线观看www色| 国内自拍视频在线观看| www中文字幕在线观看| 欧美日韩亚洲国内综合网| 免费看av大片| 亚洲男人的天堂成人| 精品无吗乱吗av国产爱色| 在线免费看av| 国产精品一卡二卡三卡| 午夜伦全在线观看| 国产精品久久久久久久牛牛| 国产三级视频| 在线观看免费高清完整| 欧美色第一页| 国产精品扒开做爽爽爽的视频| 精品成人免费自拍视频| 黄色一级片视频| 精品偷拍激情视频在线观看| 欧美精品小视频| 精品久久av| 免费国产阿v视频在线观看| 永久免费在线观看| av在线中文| 国产精品粉嫩av| 青青国产在线| 在线播放国产区| 国产精品一区在线看| 夜夜爽夜夜操| 国产视频在线播放| 麻豆精品永久免费视频| 精品伦理一区二区| 国产9色视频| 国产一二三四| 久久国产精品久久久久久小说| 国产在线拍揄自揄拍视频| 福利视频网站导航| 日本在线观看| 大香伊人中文字幕精品| 国产精品美女视频免费观看软件| 麻豆精品视频入口| av在线天堂| 永久免费不卡在线观看黄网站 | 久久久久久77777| 精品176二区| 中文字幕av免费| 在线中文字幕av| 国产激情三区| 国产99在线|亚洲| 国产成人亚洲综合小说区| 国产一区二区三区福利| 精品久久久久一区二区三区| 二人午夜免费观看在线视频| 男人天堂99| 免费在线你懂的| 青草青在线视频| www.操.com| 国产在线观看av| 国产精品自产拍在线观看2019| 九九在线免费视频| 午夜视频在线免费| 亚洲成av人影片在线观看| 69视频在线观看| av中文在线资源| 欧美日韩一区二区三区视视频| 人成在线免费视频| 国产精品视频一区二区三区麻豆| 黄色片视频在线观看| 午夜av电影| 亚洲精品少妇久久久久久| 国产videos| 亚洲精品少妇久久久久久| 久久久久久91精品色婷婷| 国产精品冒白浆免费视频| 99久久99热久久精品免费看| 欧美日韩视频精品一区二区| 国产三级av在线| www狠狠操| 国产精品久久一区二区三区不卡| 天天插天天狠天天透| 国产一级片网站| 日本在线天堂| 2021av在线| 中文字幕国产欧美| 日本精品一区二区三区在线播放| 99热在线免费观看| 精品国产美女福利到在线不卡| 免费看ww视频网站入口| 999精品网| 国产午夜视频| 久久国产综合视频| 亚洲欧美综合乱码精品成人网| 国产麻豆精品入口在线观看 | 亚洲人在线播放| 久草在线视频网| 午夜在线不卡| 92久久精品| 91嫩草在线播放| 99热在线观看免费| 国产爆初菊在线观看免费视频网站| 青青草观看免费视频在线| 在线观看av中文| 精品99又大又爽又硬少妇毛片| www.操操操.com| 国产成人午夜| 国产高潮又爽又无遮挡又免费| 99视频资源网| 国产丝袜在线观看视频| 中文字幕久热在线精品| 国产乱xxⅹxx国语对白| 久热免费视频| 精品孕妇一区二区三区| 精品资源在线看| 国产精品一区二区三区视频网站 | 美女被人操视频在线观看| www.香蕉视频在线观看| 日本免费视频www| 国产精品毛片一区二区三区四区| gogogogo高清视频在线| 影音先锋中文字幕在线| 亚洲激情丁香| 嫩草在线播放| 国产三线在线| av黄色在线观看| 欧美日韩在线资源| 中文字幕在线观看av| 五月天亚洲激情| 91中文字幕| 超碰国产在线| 国产精品合集一区二区 | а√最新版地址在线天堂| 俺来俺也去www色在线观看| www在线视频| www.色婷婷| 国产中文字幕在线看| 国产黄色免费看| 日本亚洲精品| 国产精品久久久久一区二区国产 | 国产黄色片大全| 亚洲大香人伊一本线| 成网站在线观看人免费| 精品国产免费观看一区| 五月天丁香在线| a视频在线观看免费| 国产经典av| 好男人免费精品视频| 伊人伊人av电影| 国产精品入口麻豆电影| 亚洲精品久久久成人|