XML片段:
- <AA>
- <BB>foo</BB>
- <CC>bar</CC>
- <DD>baz</DD>
- <EE>bar</EE>
- </AA>
如何选择< AA>的所有子节点有酒吧作为其内容?在上面的示例中,我想选择< CC>和< EE> ;.我在想这个解决方案是这样的:
- <xsl:template match="AA">
- <xsl:for-each select="???" />
- </xsl:template>
OP的问题的最简单的解决方案之一是以下XPath表达式:
- */*[.='bar']
请注意,没有涉及XSLT指令 – 这只是一个XPath表达式,所以问题只能被标记为XPath.
从这里开始,可以通过各种方式在XSLT中使用XPath表达式,例如在所有选定的节点上应用模板.
例如,下面是XSLT转换,它接收XML文档并生成另一个XML文档,其中所有元素 – < AA>的子节点其内容不等于“bar”删除:
- <xsl:stylesheet version="1.0"
- xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
- <xsl:output omit-xml-declaration="yes" indent="yes"/>
- <xsl:template match="node()|@*">
- <xsl:copy>
- <xsl:apply-templates select="node()|@*"/>
- </xsl:copy>
- </xsl:template>
- <xsl:template match="AA">
- <xsl:copy>
- <xsl:apply-templates select="*[. = 'bar']"/>
- </xsl:copy>
- </xsl:template>
- </xsl:stylesheet>
当这种转换应用于原始XML文档时:
- <AA>
- <BB>foo</BB>
- <CC>bar</CC>
- <DD>baz</DD>
- <EE>bar</EE>
- </AA>
想要的结果是:
- <AA>
- <CC>bar</CC>
- <EE>bar</EE>
- </AA>
注意:
在匹配模式中,我们通常不需要指定绝对的XPath表达式,而只需要指定一个相对的XPath表达式,因此,完整的XPath表达式自然地简化为该匹配模式:
- *[. = 'bar']