在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片段。
XSLT处理器会根据 xsl:output 的 method 属性决定如何序列化结果。若想让浏览器正确解析生成的标签,必须显式声明:
<xsl:output method="html" encoding="UTF-8" indent="yes"/>
这会让处理器对 <div>、<code> 等做 HTML 特定处理(比如自动闭合 <br>),也影响是否默认转义内容。
最安全、推荐的方式是把要插入的HTML结构预先构造成节点(而非字符串),再用 xsl:copy-of 复制过去。例如:
立即学习“前端免费学习笔记(深入)”;
<xsl:variable name="myHtml"> <div class="note"><strong>注意</strong>:此处有 & 符号</div> </xsl:variable> <xsl:copy-of select="$myHtml/node()"/>
因为 $myHtml 是一个结果树片段(RTF)或临时文档节点,xsl:copy-of 会原样复制其结构,不会转义。
全站生成html留言本采用ajax程序应该说还是比较短小精悍的不到1M另外还支持分栏目关键字和描述系统支持无限级分类生成静态HTML、ajax 、数据库内容替换、自定义标签后台用户名admin密码000123
0
虽然 xsl:value-of disable-output-escaping="yes" 能强制不转义字符串,但它有明显缺陷:
仅当必须从纯文本字段动态拼接HTML(如 CMS 导出的富文本字段)且无法改数据结构时才考虑,且务必确保字符串本身是合法、已转义过的HTML。
以下情况仍会导致标签被显示为文本而非渲染:
xml 或未声明 xsl:output,导致浏览器以 XML 模式解析xsl:value-of 输出含 的字符串
concat() 拼接字符串基本上就这些。核心原则是:把HTML当结构处理,而不是当字符串拼接。
以上就是XSLT怎么生成HTML的标签而不转义内容的详细内容,更多请关注php中文网其它相关文章!
HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号