XSLT <xsl:pilih> Elemen
Elemen <xsl:choose> digunakan bersama dengan <xsl:when> dan <xsl:otherwise> untuk mengekspresikan beberapa pengujian kondisional.
Elemen <xsl:pilih>
Sintaksis
<xsl:choose>
<xsl:when test="expression">
... some output ...
</xsl:when>
<xsl:otherwise>
... some output ....
</xsl:otherwise>
</xsl:choose>
Di mana menempatkan Kondisi Pilih
Untuk menyisipkan beberapa pengujian bersyarat terhadap file XML, tambahkan elemen <xsl:choose>, <xsl:when>, dan <xsl:otherwise> ke file XSL:
Contoh
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<h2>My CD Collection</h2>
<table border="1">
<tr bgcolor="#9acd32">
<th>Title</th>
<th>Artist</th>
</tr>
<xsl:for-each select="catalog/cd">
<tr>
<td><xsl:value-of select="title"/></td>
<xsl:choose>
<xsl:when test="price > 10">
<td bgcolor="#ff00ff">
<xsl:value-of select="artist"/></td>
</xsl:when>
<xsl:otherwise>
<td><xsl:value-of select="artist"/></td>
</xsl:otherwise>
</xsl:choose>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Kode di atas akan menambahkan warna latar belakang merah muda ke kolom "Artis" KETIKA harga CD lebih tinggi dari 10.
Contoh lain
Berikut adalah contoh lain yang berisi dua elemen <xsl:when>:
Contoh
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<h2>My CD Collection</h2>
<table border="1">
<tr bgcolor="#9acd32">
<th>Title</th>
<th>Artist</th>
</tr>
<xsl:for-each select="catalog/cd">
<tr>
<td><xsl:value-of select="title"/></td>
<xsl:choose>
<xsl:when test="price > 10">
<td bgcolor="#ff00ff">
<xsl:value-of select="artist"/></td>
</xsl:when>
<xsl:when test="price > 9">
<td bgcolor="#cccccc">
<xsl:value-of select="artist"/></td>
</xsl:when>
<xsl:otherwise>
<td><xsl:value-of select="artist"/></td>
</xsl:otherwise>
</xsl:choose>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Kode di atas akan menambahkan warna latar belakang merah muda ke kolom "Artis" KETIKA harga CD lebih tinggi dari 10, dan warna latar abu-abu KETIKA harga CD lebih tinggi dari 9 dan lebih rendah atau sama dengan 10.