次の XML ファイルがあります。
<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xsl" href="loci.xsl"?>
<Loci>
<Locus>
<Id>LOCUS_1</Id>
<Alleles>
<Allele>
<Name>Allele_1</Name>
<Description>Description for 1</Description>
</Allele>
</Alleles>
</Locus>
<Locus>
<Id>LOCUS_2</Id>
<Alleles>
<Allele>
<Name>Allele_2_a</Name>
<Description>Description for 2 a</Description>
</Allele>
<Allele>
<Name>Allele_2_b</Name>
<Description>Description for 2 b</Description>
</Allele>
</Alleles>
</Locus>
<Locus>
<Id>LOCUS_3</Id>
<Alleles>
<Allele>
<Name>Allele_3</Name>
<Description>Description for 3</Description>
</Allele>
</Alleles>
</Locus>
</Loci>
次の XSL を使用して HTML テーブルに変換し、埋め込まれた CSS でスタイルを設定します。
<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<head>
<style type="text/css">
#report
{
font-family: "Lucida Sans Unicode", "Lucida Grande", Sans-Serif;
font-size: 12px;
margin: 45px;
width: 90%;
text-align: left;
border-collapse: collapse;
color: #039;
}
#report th
{
font-size: 16px;
font-weight: normal;
padding: 10px 8px;
color: #039;
text-align: left;
border-right: 1px solid #9baff1;
border-left: 1px solid #9baff1;
border-top: 2px solid #9baff1;
border-bottom: 2px solid #9baff1;
}
#report td
{
padding: 5px;
color: #669;
border-right: 1px solid #aabcfe;
border-left: 1px solid #aabcfe;
}
#report tr:nth-child(even)
{
background: #e8edff;
}
</style>
</head>
<body>
<table border="1" id="report">
<tr>
<th>Locus</th>
<th>Allele</th>
<th>Description</th>
</tr>
<xsl:for-each select="Loci/Locus">
<xsl:for-each select="Alleles/Allele">
<tr>
<xsl:if test="position() = 1">
<td rowspan="{last()}">
<xsl:value-of select="ancestor::Locus[1]/Id"/>
</td>
</xsl:if>
<td><xsl:value-of select="Name"/></td>
<td><xsl:value-of select="Description"/></td>
</tr>
</xsl:for-each>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
結果は次のようになります。
ただし、最初の列に応じてゼブラの縞模様を交互にしたいと思います。
したがって、最初の座位の行は完全に紫色で問題ありませんが、2 番目の座位のセルもAllele_2_b
とDescription for 2 b
白で表示し、3 番目の座位の行全体を再び紫色にしたいと思います。
どうすればこれを達成できますか?