![](/img/trans.png)
[英]Loading HTML fragments asynchronous in a web page that is generated using XSLT & XML
[英]How to convert XML (generated from dataset) to HTML using xslt
試圖從xml中獲取html,我已經從數據集生成了以下xml,這意味着我無法更改XML的結構。我認為我在第二個循環中缺少A和B循環。
<Myds>
<A>
<col1>Row1</col1>
<col2>1</col2>
<col3>2</col3>
</A>
<A>
<col1>Row2</col1>
<col2>4</col2>
<col3>3</col3>
</A>
<B>
<col1>Row1</col1>
<col2>1</col2>
<col3>2</col3>
</B>
<B>
<col1>Row2</col1>
<col2>4</col2>
<col3>3</col3>
</B>
</Myds>
這是XSL
<xsl:stylesheet version='1.0' xmlns:xsl='http://www.w3.org/1999/XSL/Transform'>
<xsl:template match='/'>
<xsl:for-each select ='./Myds'>
<table>
<xsl:for-each select ='A'>
<tr>
<td><xsl:value-of select='col1'/></td>
<td><xsl:value-of select='col2'/></td>
<td><xsl:value-of select='col3'/></td>
</tr>
</xsl:for-each>
</table>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
我有這個輸出
<?xml version="1.0" encoding="utf-8"?>
<table>
<tr><td>Row1</td><td>1</td><td>2</td></tr>
<tr><td>Row2</td><td>4</td><td>3</td></tr>
</table>
但是我期待着這個
<table>//(For Table A)
<tr><td>Row1</td><td>1</td><td>2</td></tr>
<tr><td>Row2</td><td>4</td><td>3</td></tr>
</table>
<table>//(For Table B)
<tr><td>Row1</td><td>1</td><td>2</td></tr>
<tr><td>Row2</td><td>4</td><td>3</td></tr>
</table>
我想我需要這樣的東西,但不完全是這樣...
<xsl:stylesheet version='1.0' xmlns:xsl='http://www.w3.org/1999/XSL/Transform'>
<xsl:template match='/'>
<xsl:for-each select ='./Myds'>
<table>
<xsl:for-each select ='UNIQUE SECOND NODE'>
<tr>
<td><xsl:value-of select='col1'/></td>
<td><xsl:value-of select='col2'/></td>
<td><xsl:value-of select='col3'/></td>
</tr>
</xsl:for-each>
</table>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
xslt區分大小寫; 每行都需要
<td><xsl:value-of select='col1'/></td>
<td><xsl:value-of select='col2'/></td>
<td><xsl:value-of select='col3'/></td>
並且您需要使用Muenchian分組來為每個具有相同名稱的元素獲取一個<table>
:
<xsl:stylesheet version='1.0' xmlns:xsl='http://www.w3.org/1999/XSL/Transform'>
<xsl:key name="byTable" match="/Myds/*" use="name()" />
<xsl:template match='/'>
<xsl:for-each select="Myds/*[generate-id() = generate-id(key('byTable', name())[1])]">
<table>
<xsl:comment>for <xsl:value-of select="name()"/></xsl:comment>
<xsl:for-each select ="key('byTable', name())">
<tr>
<td><xsl:value-of select='col1'/></td>
<td><xsl:value-of select='col2'/></td>
<td><xsl:value-of select='col3'/></td>
</tr>
</xsl:for-each>
</table>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.