这就是您实际需要的 XSLT 1.0 转换。
它创建了一个结构良好的 HTML 嵌套树,没有任何disable-output-escaping
技巧。
<xsl:stylesheet
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
>
<xsl:output method="html" indent="yes" />
<!-- index Nodes by their owner ID -->
<xsl:key name="kNodeByOwnerId" match="Node" use="Prp[@name = 'owner id']/@value" />
<xsl:template match="/">
<html>
<head>
<style type="text/css"><![CDATA[
body {
font-size: 14px;
font-family: verdana;
background-color: white;
}
div.root {
padding: 0px 0px 2px 0px;
}
div.root div {
padding: 0px 0px 0px 0px;
margin-left: 3em;
}
div.remark {
margin-left: 2em;
}
img.icon {
padding-right: 5px;
}
span.log {
font-weight: bold;
}
span.log.fail {
color: red;
}
span.log.pass {
color: green;
}
span.log.info {
color: blue;
}
]]></style>
</head>
<body>
<!-- output "top level" nodes, i.e. those with owner ID -1 -->
<xsl:apply-templates select="key('kNodeByOwnerId', '-1')">
<xsl:sort select="substring-after(@name, 'message ')" data-type="number" />
<xsl:with-param name="containerClass" select="'root'" />
</xsl:apply-templates>
</body>
</html>
</xsl:template>
<xsl:template match="Node">
<xsl:param name="containerClass" select="''" />
<xsl:variable name="messageClass">
<xsl:apply-templates select="Prp[@name = 'type']" />
</xsl:variable>
<div class="{$containerClass}">
<img class="icon" src="./{$messageClass}.png" />
<span class="log {$messageClass}">
<xsl:value-of select="Prp[@name='message']/@value"/>
</span>
<xsl:apply-templates select="Prp[@name = 'remarks']" />
<!-- output nodes that belong to this node (recursive!) -->
<xsl:apply-templates select="key('kNodeByOwnerId', Prp[@name = 'id']/@value)">
<xsl:sort select="substring-after(@name, 'message ')" data-type="number" />
</xsl:apply-templates>
</div>
</xsl:template>
<xsl:template match="Prp[@name = 'remarks']">
<xsl:if test="normalize-space(@value) != ''">
<div class="remark">
<img class="icon" src="./info.png" />
<xsl:value-of select="@value"/>
</div>
</xsl:if>
</xsl:template>
<xsl:template match="Prp[@name = 'type']">
<xsl:choose>
<xsl:when test="@value = '0'">pass</xsl:when>
<xsl:when test="@value = '4'">info</xsl:when>
<xsl:otherwise>fail</xsl:otherwise>
</xsl:choose>
</xsl:template>
</xsl:stylesheet>
注意使用<xsl:key>
. 可以在我的较早答案中找到密钥如何工作的详尽解释。
该代码非常简单明了,因此您应该可以轻松理解它的作用。不要犹豫,问是否有任何不清楚的地方。
我强烈建议将 CSS 代码放入单独的文件中。