我在XSLT处理器的行为中遇到了一些特殊的差异。我想知道这背后的原因是什么,以及在处理器差异的某处是否有完整的概述。
我测试了以下简单的变换(具有虚设输入):XSLT文本输出处理器差异
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format">
<xsl:output method="text"/>
<xsl:template match="/">
<xsl:text>1=
2=
3=
4=

end</xsl:text>
</xsl:template>
</xsl:stylesheet>
运行,输出为:
1=
2=
3=
4=
end
在所有情况下,以十六进制在=
后,并在4=
行后,两个字符已被添加,0D
和0A
。 显然,XML间谍替换为&xA;
或&xD;
由全CR + LF发生时被请求的顺序CR和LF,后右彼此除了每个请求,(见3 =部分)。
但saxon9he运行的时候,我得到我运行了2.0版处理器1.0样式的警告,并且输出
1=
2=3=
4=
end
在这种情况下,&xA;
所有的请求都取而代之的是0D 0A
(所以在LF前添加了CR),但是对于&xD;
的请求输出所请求的CR,而不是另外的LF。
在XML间谍重新运行XSLT版本设置为2.0给出了相同的结果为1.0,所以我想这是不是导致此两个XSLT版本不同的约定。
很可能,这只是我们必须了解的工具之间的差异,但我想知道这个问题是否还有更多要说的。
如果输出在样式表文件,一个期待与单一CR RESP的第二个版本。 LF类。 – 2012-02-06 23:47:25