多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > web前端 > htmlcss > 使用xslt將xml解析成xhtml

使用xslt將xml解析成xhtml

來源:程序員人生   發布時間:2014-02-10 09:43:05 閱讀次數:2718次

使用xslt進行解析的基本格式是這樣的:如

<?xml version="1.0" encoding="GB2312"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method='html' version='1.0' encoding='GB2312' indent='yes'/>

<xsl:template match="/">
<html>
<body>
//這里可以包含一些xhtml的標簽
</body>
</html>
</xsl:template>
</xsl:stylesheet>

XSL 指擴展樣式表語言(EXtensible Stylesheet Language),xsl是xml的樣式表,xsl 包括3部分,分別是:xslt(一種用于轉換 XML 文檔的語言)、x-path(一種用于在 XML 文檔中導航的語言)、xsl-fo(一種用于格式化 XML 文檔的語言),可以在http://www.w3cschool.cn/這個網站中找到相關內容的教程。

像前面代碼描述的那樣,xslt以xml的版本作為開始,用<xsl:style-sheeet ...>...</xsl:style-sheeet>的格式進行轉換。由于是初次接觸xslt,對它了解并不是很透徹,下面只是羅列一些我在學習和使用它的時候碰到的一些要點;

一、遞歸以及傳參數方法:

以一顆家族樹為例子,xml文件是這樣的:

<?xml version="1.0" encoding="ISO-8859-1"?>
<?xml-stylesheet type="text/xsl" href="digui.xsl"?>
<person name="Otto" sex="mael" age="60">
  <person name="Sandra" sex="mael" age="35">
  <person name="Lichao" sex="femael" age="34">
   <person name="Zhangsan" sex="mael" age="12"/>
  </person>
  <person name="Eric" sex="femael" age="36">
   <person name="HaLi" sex="mael" age="18"/>
  </person>
  <person name="Lisi" sex="mael" age="30">
   <person name="HeLi" sex="mael" age="6"/>
   <person name="Andy" sex="femael" age="13"/>
  </person>
  </person>
</person>
現在要寫一個xslt把家族的關系給表達出來,其實家族的關系就是一顆家族樹,所以我們通過輸出不同層次的縮進來表達這樣的關系,最大的祖宗,然后按輩份分別進行縮進,最小輩份的排在最后面,縮進最多,這樣一顆樹的層次就出來了;下面是xsl文件的代碼:

<?xml version="1.0" encoding="GB2312"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method='html' version='1.0' encoding='GB2312' indent='yes'/>

<xsl:template match="/">
<html>
<body>
<xsl:apply-templates select="person">
<xsl:with-param name="level" select="'0'"/>
</xsl:apply-templates>
</body>
</html>
</xsl:template>

<xsl:template match="person">
<xsl:param name="level"/>
<p style="text-indent:{$level}em">name:<xsl:value-of select="@name"/>,sex:<xsl:value-of select="@sex"/>,age:<xsl:value-of select="@age"/></p>
<xsl:apply-templates select="person">
<xsl:with-param name="level" select="$level + 2"/>
</xsl:apply-templates>
</xsl:template>
</xsl:stylesheet>
在這里我們先在模板中定義了一個叫level的參數,用<xsl:param name="level"/>這樣的語法,然后在主template(<xsl:template match="/">...</xsl:template>)添加模板的時候給參數賦值,

<xsl:apply-templates select="person"> <xsl:with-param name="level" select="'0'"/> </xsl:apply-templates>,參數level的值一開始賦值為“0”,而我們用參數level的值($level)來作縮進的值,如text-indent:{$level}em,所以渲染xml內容的時候,第一層沒有縮進,渲染完第一層后,我們通過

<xsl:apply-templates select="person">
<xsl:with-param name="level" select="$level + 2"/>
</xsl:apply-templates>

這樣的方法將參數level的值進行了累加從而實現了遞歸,這樣每渲染一層,參數值就加上2,從而實現了不同層次的縮進來實現家族樹的結構;這里還要說一下,我們通過@+屬性如@name來取節點屬性的值。

二、用參數實現隔行換色:

還是引用上面的例子,以及參數level,我們在遞歸的時候給參數+1(奇數)而不是+2 (偶數),通過(.. test="$level mod 2 = 0")或(.. test="$level mod 2 = 1")就可以實現選取奇數行還是偶數行,我們用<xsl:choose> <xsl:when test="$level mod 2 = 0">...</xsl:when> <xsl:otherwise>...</xsl:otherwise> </xsl:choose>給奇數行和偶數行不同的background-color,從而實現了隔行換色的效果,具體代碼如下:

<?xml version="1.0" encoding="GB2312"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method='html' version='1.0' encoding='GB2312' indent='yes'/>

<xsl:template match="/">
<html>
<body>
<xsl:apply-templates select="person">
<xsl:with-param name="level" select="'0'"/>
</xsl:apply-templates>
</body>
</html>
</xsl:template>

<xsl:template match="person">
<xsl:param name="level"/>
<xsl:choose>
<xsl:when test="$level mod 2 = 0">
<p style="text-indent:{$level}em;background-color:#DDD">name:<xsl:value-of select="@name"/>,sex:<xsl:value-of select="@sex"/>,age:<xsl:value-of select="@age"/></p>
</xsl:when>
<xsl:otherwise>
<p style="text-indent:{$level}em;background-color:#EEE">name:<xsl:value-of select="@name"/>,sex:<xsl:value-of select="@sex"/>,age:<xsl:value-of select="@age"/></p>
</xsl:otherwise>
<xsl:apply-templates select="person">
<xsl:with-param name="level" select="$level + 1"/>
</xsl:apply-templates>
</xsl:template>
</xsl:stylesheet>

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 国产欧美一区二区三区视频在线观看 | 免费看在线爱爱小视频 | 黄色网一级片 | 日本护士高清xxxxx | 琪琪免费影院 | 精品欧美一区二区三区在线观看 | 一区二区三区高清在线观看 | 亚洲在线观看一区 | 亚洲视频一区 | 大杳蕉伊人狼人久久一本线 | 亚洲国产精品第一区二区 | 亚洲精品一区二区 | 日本性色视频 | xxxxx做受大片视频免费 | 国产在线精品一区二区三区 | 国产精品一区欧美激情 | 啄木乌欧美一区二区三区 | 毛片毛| 国产福利视频一区二区三区 | xxxxxx日本处大片免费看 | 国产精品成人第一区 | 亚洲国产精品欧美日韩一区二区 | 67194在线午夜亚洲 | 午夜网站在线观看 | 中文字幕第7页 | 国产欧美综合在线一区二区三区 | 免费播放欧美毛片欧美a | 亚洲视频在线视频 | 国产亚洲精品一区久久 | 亚洲永久在线 | 欧美成人午夜视频 | 中文字幕乱码中文乱码51精品 | 亚洲另类图 | 国产高清精品一级毛片 | 亚洲综合区图片小说区 | 亚洲黄色高清视频 | 欧美人与动性视频在线观 | www久| 国产大片www | 欧美日韩国产一区二区三区 | 欧美黄色片在线观看 |