我需要转换以下 xml 文档:
<a>
<b/>
<c/>
myText
</a>
进入这个:
<a>
<b/>
<c/>
differentText
</a>
所以,我写了这个 XSLT 文档
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" version="1.0" omit-xml-declaration="no" />
<xsl:template match="/a/text()">
<a>
<b/>
<c/>
differentText
</a>
</xsl:template>
</xsl:stylesheet>
这样,我得到以下结果:
<?xml version="1.0" encoding="utf-8"?>
<a>
<b /><c />
differentText
</a>
<a>
<b /><c />
differentText
</a>
<a>
<b /><c />
differentText
</a>
结果出现重复 3 次,因为正在进行 3 场比赛。为什么?我可以修复它吗?谢谢
排除仅包含空格的文本节点。了解并使用<xsl:strip-space>操作说明.
这种转变:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="a/text()">
<xsl:text>Diferent text</xsl:text>
</xsl:template>
</xsl:stylesheet>
当应用于提供的 XML 文档时,会产生所需的正确结果.
特定模板的匹配表达式中不需要复杂的谓词!
我们应该努力寻求最简单、最短、最优雅、最可读、最容易理解的解决方案,充分利用语言的力量。
这样的解决方案很可能是最容易理解、最容易实现并且最有可能被任何 XSLT 处理器优化的,从而实现最有效的实现。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)