在XSLT中生成HTML标签不转义的关键是设xsl:output method="html",并用xsl:copy-of复制节点树;禁用disable-output-escaping以避免安全与兼容性问题。
标签而不转义内容">
在XSLT中生成HTML标签而不转义内容,关键在于使用 xsl:output 正确设置输出方法,并用 xsl:copy-of 或 xsl:value-of disable-output-escaping="yes"(不推荐但有时需兼容旧版)来输出未转义的HTML片段。
确保输出方法为 HTML
XSLT处理器会根据 xsl:output 的 method 属性决定如何序列化结果。若想让浏览器正确解析生成的标签,必须显式声明:
这会让处理器对 最安全、推荐的方式是把要插入的HTML结构预先构造成节点(而非字符串),再用 因为 虽然 仅当必须从纯文本字段动态拼接HTML(如 CMS 导出的富文本字段)且无法改数据结构时才考虑,且务必确保字符串本身是合法、已转义过的HTML。 以下情况仍会导致标签被显示为文本而非渲染: 基本上就这些。核心原则是:把HTML当结构处理,而不是当字符串拼接。、 等做 HTML 特定处理(比如自动闭合 ),也影响是否默认转义内容。
用 xsl:copy-of 输出已构造的节点树
xsl:copy-of 复制过去。例如:$myHtml 是一个结果树片段(RTF)或临时文档节点,xsl:copy-of 会原样复制其结构,不会转义。避免使用 disable-output-escaping(除非必要)
xsl:value-of disable-output-escaping="yes" 能强制不转义字符串,但它有明显缺陷:
常见陷阱与提醒
xml 或未声明 xsl:output,导致浏览器以 XML 模式解析
本节点却用 xsl:value-of 输出含 的字符串
concat() 拼接字符串








