XSLT如何输出HTML?

小老鼠
发布: 2025-09-05 10:41:02
原创
946人浏览过
<blockquote>XSLT输出HTML需定义xsl:output method="html",通过模板匹配XML节点生成HTML结构,利用xsl:value-of提取数据,xsl:attribute设置动态属性,并可嵌入link和script标签引入CSS与JavaScript,实现完整网页生成。</blockquote> <p><img src="https://img.php.cn/upload/article/001/221/864/175704006473330.jpg" alt="xslt如何输出html?"></p> <p>XSLT要输出HTML,其核心在于将XML数据结构通过定义好的转换规则,映射并生成符合HTML语法的标记语言。简单来说,它就像一个模板引擎,你告诉它看到什么样的XML数据就生成什么样的HTML结构。</p> <h3>解决方案</h3> <p>要让XSLT输出HTML,你需要三样东西:一份XML源文档、一份XSLT样式表、以及一个XSLT<a style="color:#f60; text-decoration:underline;" title="处理器" href="https://www.php.cn/zt/16030.html" target="_blank">处理器</a>。</p> <p>首先,在XSLT样式表的根元素 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false;">xsl:stylesheet</pre>
登录后复制
</div> 或 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false;">xsl:transform</pre>
登录后复制
</div> 中,必须明确指定输出方法为HTML。这通过 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false;">xsl:output</pre>
登录后复制
&amp;lt;/div&amp;gt; 元素来完成:&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<xsl:output method=&amp;quot;html&amp;quot; indent=&amp;quot;yes&amp;quot;/>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;这里的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;method=&amp;quot;html&amp;quot;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 是关键,它告诉处理器按照HTML的规则来序列化输出,比如空元素(如 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<br>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;)会输出为 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<br>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 而不是 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<br/>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;,并且会处理HTML实体。&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;indent=&amp;quot;yes&amp;quot;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 则让输出的HTML更易读。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;&amp;lt;span&amp;gt;立即学习&amp;lt;/span&amp;gt;“&amp;lt;a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank"&amp;gt;前端免费学习笔记(深入)&amp;lt;/a&amp;gt;”;&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;接着,你需要在XSLT样式表中编写模板(&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:template&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;)。这些模板会根据XPath表达式匹配XML文档中的节点,然后生成相应的HTML结构。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;例如,一个最基本的转换可能长这样:&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;XML源文档 (data.xml):&amp;lt;/strong&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<bookstore> <book category=&amp;quot;cooking&amp;quot;> <title lang=&amp;quot;en&amp;quot;>Everyday Italian</title> <author>Giada De Laurentiis</author> <year>2005</year> <price>30.00</price> </book> <book category=&amp;quot;web&amp;quot;> <title lang=&amp;quot;en&amp;quot;>Learning XML</title> <author>Erik T. Ray</author> <year>2003</year> <price>39.95</price> </book> </bookstore>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;XSLT样式表 (transform.xslt):&amp;lt;/strong&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<?xml version="1.0" encoding="UTF-8"?> <xsl:stylesheet version="1.0" xmlns:xsl=&amp;quot;http://www.w3.org/1999/XSL/Transform&amp;quot;> <xsl:output method=&amp;quot;html&amp;quot; indent=&amp;quot;yes&amp;quot;/> <xsl:template match=&amp;quot;/&amp;quot;> <html> <head> <title>我的书店</title> </head> <body> <h1>书店列表</h1> <ul> <xsl:apply-templates select=&amp;quot;bookstore/book&amp;quot;/> </ul> </body> </html> </xsl:template> <xsl:template match=&amp;quot;book&amp;quot;> <li> <strong><xsl:value-of select="title"/></strong> by <xsl:value-of select="author"/> (<xsl:value-of select="year"/>) - $<xsl:value-of select="price"/> </li> </xsl:template> </xsl:stylesheet>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;处理结果 (HTML输出):&amp;lt;/strong&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:html;toolbar:false;'&amp;gt;<!DOCTYPE html> <html> <head> <meta http-equiv=&amp;quot;Content-Type&amp;quot; content=&amp;quot;text/html; charset=UTF-8&amp;quot;> <title>我的书店</title> </head> <body> <h1>书店列表</h1> <ul> <li> <strong>Everyday Italian</strong> by Giada De Laurentiis (2005) - $30.00 </li> <li> <strong>Learning XML</strong> by Erik T. Ray (2003) - $39.95 </li> </ul> </body> </html>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;在这个例子中,&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:template match=&amp;quot;/&amp;quot;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 匹配整个XML文档的根节点,然后生成HTML的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<html>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<head>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<body>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 结构。&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:apply-templates select=&amp;quot;bookstore/book&amp;quot;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 则会找到所有 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<book>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 节点,并为每个节点应用一个匹配的模板。第二个 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:template match=&amp;quot;book&amp;quot;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 就是为每个 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<book>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 节点生成一个 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<li>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 列表项,并提取其中的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;title&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;author&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;year&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;price&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 内容。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;这套机制让我觉得XSLT有点像“声明式编程”的早期尝试,你不是告诉&amp;lt;a style="color:#f60; text-decoration:underline;" title="计算机" href="https://www.php.cn/zt/16013.html" target="_blank"&amp;gt;计算机&amp;lt;/a&amp;gt;“一步步怎么做”,而是告诉它“当看到这个结构时,应该变成那个结构”。&amp;lt;/p&amp;gt; &amp;lt;h3&amp;gt;XSLT在生成HTML时如何处理各种元素和属性?&amp;lt;/h3&amp;gt; &amp;lt;p&amp;gt;XSLT在生成HTML时,处理元素和属性的方式相当直接,但也需要一些技巧。基本上,任何不在XSLT命名空间(&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xmlns:xsl=&amp;quot;http://www.w3.org/1999/XSL/Transform&amp;quot;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;)内的元素,都会被原样输出到结果文档中。这就是为什么我们可以在 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:template&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 内部直接写 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<html>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<head>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<body>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<h1>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<ul>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;, &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<li>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 等HTML标签。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;对于属性,你可以直接在输出的HTML元素上写死属性,比如 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<a href=&amp;quot;index.html&amp;quot;>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;。但更多时候,属性值是动态的,需要从XML源数据中提取。这时,我们使用 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:attribute&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 元素。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;例如,如果你想根据XML中的一个属性来设置HTML元素的属性:&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;XML:&amp;lt;/strong&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<product id=&amp;quot;p101&amp;quot; status=&amp;quot;new&amp;quot;> <name>Awesome Gadget</name> </product>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;XSLT:&amp;lt;/strong&amp;gt;&amp;lt;/p&amp;gt; &amp;lt;div class="aritcle_card"&amp;gt; &amp;lt;a class="aritcle_card_img" href="/ai/%E5%A6%82%E7%9F%A5ai%E7%AC%94%E8%AE%B0"&amp;gt; &amp;lt;img src="https://img.php.cn/upload/ai_manual/000/000/000/175679994166405.png" alt="如知AI笔记"&amp;gt;&amp;lt;/a&amp;gt; &amp;lt;div class="aritcle_card_info"&amp;gt; &amp;lt;a href="/ai/%E5%A6%82%E7%9F%A5ai%E7%AC%94%E8%AE%B0"&amp;gt;如知AI笔记&amp;lt;/a&amp;gt; &amp;lt;p&amp;gt;如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型&amp;lt;/p&amp;gt; &amp;lt;div class=""&amp;gt; &amp;lt;img src="/static/images/card_xiazai.png" alt="如知AI笔记"&amp;gt;&amp;lt;span&amp;gt;27&amp;lt;/span&amp;gt; &amp;lt;/div&amp;gt; &amp;lt;/div&amp;gt; &amp;lt;a href="/ai/%E5%A6%82%E7%9F%A5ai%E7%AC%94%E8%AE%B0" class="aritcle_card_btn"&amp;gt; &amp;lt;span&amp;gt;查看详情&amp;lt;/span&amp;gt; &amp;lt;img src="/static/images/cardxiayige-3.png" alt="如知AI笔记"&amp;gt;&amp;lt;/a&amp;gt; &amp;lt;/div&amp;gt; &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<xsl:template match=&amp;quot;product&amp;quot;> <div class=&amp;quot;product-item&amp;quot;> <xsl:attribute name=&amp;quot;data-id&amp;quot;> <xsl:value-of select=&amp;quot;@id&amp;quot;/> </xsl:attribute> <xsl:attribute name=&amp;quot;class&amp;quot;> product-item <xsl:value-of select=&amp;quot;@status&amp;quot;/> </xsl:attribute> <h2><xsl:value-of select=&amp;quot;name&amp;quot;/></h2> </div> </xsl:template>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;这里,我们通过 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:attribute name=&amp;quot;data-id&amp;quot;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 来创建一个 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;data-id&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 属性,其值来自XML的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;@id&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 属性。注意,&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;class&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 属性演示了如何拼接静态文本和动态值。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;此外,还有 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:element&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 可以动态生成元素名称,虽然在生成固定HTML结构时不如直接写HTML标签常用,但在某些需要根据XML数据决定输出哪个HTML标签的场景下,它就很有用了。比如,如果XML里有个 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<level>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 节点决定输出 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<h1>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 还是 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<h2>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;,&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:element&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 就能派上用场。但话说回来,对于日常的HTML输出,直接嵌入HTML标签通常更直观、更易读。&amp;lt;/p&amp;gt; &amp;lt;h3&amp;gt;XSLT转换HTML时如何处理特殊字符和编码问题?&amp;lt;/h3&amp;gt; &amp;lt;p&amp;gt;处理特殊字符和编码是任何文本处理任务中都绕不开的话题,XSLT也不例外。当XSLT将XML数据转换为HTML时,它会默认对一些HTML的特殊字符进行转义,以确保输出的HTML是格式良好且安全的。例如,&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 会被转义为 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;&amp;lt;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;,&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 会变成 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;&amp;gt;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;,&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;&amp;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 会变成 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;&amp;&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;。这是为了防止XML数据中的内容被&amp;lt;a style="color:#f60; text-decoration:underline;" title="浏览器" href="https://www.php.cn/zt/16180.html" target="_blank"&amp;gt;浏览器&amp;lt;/a&amp;gt;误解析为HTML标签或实体。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;然而,有时候你可能希望某些内容 &amp;lt;em&amp;gt;不被&amp;lt;/em&amp;gt; 转义。最典型的例子就是当XML数据本身就包含了一段HTML片段,你希望这段HTML能直接插入到输出中,而不是被转义。这时,就需要用到 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;disable-output-escaping="yes"&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 属性。这个属性可以加在 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:value-of&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 或 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:text&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 元素上。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;例如:&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;XML:&amp;lt;/strong&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<content> This is some &amp;lt;strong&amp;gt;rich&amp;lt;/strong&amp;gt; text. </content>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;XSLT (错误示范,默认转义):&amp;lt;/strong&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<p><xsl:value-of select="content"/></p> <!-- 输出: <p>This is some &amp;lt;strong&amp;gt;rich&amp;lt;/strong&amp;gt; text.</p> -->&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;XSLT (正确处理,不转义):&amp;lt;/strong&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<p><xsl:value-of select="content" disable-output-escaping="yes"/></p> <!-- 输出: <p>This is some <strong>rich</strong> text.</p> -->&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;需要注意的是,&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;disable-output-escaping&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 的使用应该非常谨慎,因为它可能会引入安全漏洞(如XSS攻击),如果XML源数据不可信,不建议随意使用。它本质上是告诉处理器“相信我,这段内容是安全的,直接输出”。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;至于编码问题,&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:output&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 元素上的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;encoding&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 属性可以用来指定输出HTML的字符编码,比如 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;encoding="UTF-8"&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;。大多数现代Web应用都推荐使用UTF-8。如果XML源文档有声明编码,XSLT处理器通常会尊重它,并在转换过程中保持一致。如果输出HTML没有明确指定编码,浏览器可能会根据HTTP头或HTML的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<meta charset="...">&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 标签来猜测。因此,在HTML的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<head>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 部分加入 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<meta charset="UTF-8">&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 是一个良好的实践,确保浏览器正确解析字符。我个人习惯总是在 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:output&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 和 HTML 的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;meta&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 标签里都写上 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;UTF-8&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;,这样能最大程度地避免乱码问题。&amp;lt;/p&amp;gt; &amp;lt;h3&amp;gt;如何在XSLT生成的HTML中引入CSS和JavaScript?&amp;lt;/h3&amp;gt; &amp;lt;p&amp;gt;在XSLT生成的HTML中引入CSS和JavaScript,其实和在普通HTML文件中引入它们没有本质区别。XSLT的任务只是“组装”出HTML结构,至于这个结构内部包含了什么链接或脚本,它并不会特别对待。&amp;lt;/p&amp;gt; &amp;lt;p&amp;gt;最常见的方法就是通过在XXSLT模板中直接输出相应的HTML标签:&amp;lt;/p&amp;gt; &amp;lt;ol&amp;gt; &amp;lt;li&amp;gt; &amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;引入CSS样式表:&amp;lt;/strong&amp;gt; 你可以在HTML的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<head>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 部分输出 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<link>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 标签,指向你的CSS文件。&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<xsl:template match=&amp;quot;/&amp;quot;> <html> <head> <title>我的页面</title> <link rel="stylesheet" type="text/css" href="/static/css/styles.css"/> <!-- 也可以引入外部CDN的CSS --> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css"/> </head> <body> <!-- ... content ... --> </body> </html> </xsl:template>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;/li&amp;gt; &amp;lt;li&amp;gt; &amp;lt;p&amp;gt;&amp;lt;strong&amp;gt;引入JavaScript脚本:&amp;lt;/strong&amp;gt; 同样,在HTML的 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<head>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 或 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<body>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 结束标签之前,输出 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<script>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 标签。&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<xsl:template match=&amp;quot;/&amp;quot;> <html> <head> <!-- ... CSS ... --> </head> <body> <!-- ... content ... --> <script src="/static/js/main.js"></script> <!-- 也可以引入外部CDN的JS --> <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script> <!-- 内联脚本 --> <script> // 你的JavaScript代码 document.addEventListener('DOMContentLoaded', function() { console.log('页面已加载完毕!'); }); </script> </body> </html> </xsl:template>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;p&amp;gt;如果JavaScript代码需要动态地从XML数据中获取值,你可以在 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<script>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 标签内部使用 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;xsl:value-of&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 来插入这些值,或者生成带有 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;data-&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 属性的HTML元素,然后JavaScript去读取这些属性。&amp;lt;/p&amp;gt;&amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class='brush:xml;toolbar:false;'&amp;gt;<xsl:template match="product"> <div class="product-card" data-product-id="{@id}" data-price="{@price}"> <h2><xsl:value-of select="name"/></h2> <button onclick="addToCart(this)">添加到购物车</button> </div> </xsl:template> <!-- 在HTML的某个地方,比如body底部 --> <script> function addToCart(button) { const productId = button.closest('.product-card').dataset.productId; const price = button.closest('.product-card').dataset.price; console.log(`添加产品ID: ${productId}, 价格: ${price} 到购物车`); // 实际的购物车逻辑 } </script>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt;&amp;lt;/li&amp;gt; &amp;lt;/ol&amp;gt; &amp;lt;p&amp;gt;这种方式的优点是直观且符合Web标准。XSLT只负责把 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<link>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 和 &amp;lt;div class="code" style="position:relative; padding:0px; margin:0px;"&amp;gt;&amp;lt;pre class="brush:php;toolbar:false;"&amp;gt;<script>&amp;lt;/pre&amp;gt;
登录后复制
&amp;lt;/div&amp;gt; 标签“打印”出来,后续的资源加载和执行完全由浏览器负责。在我看来,XSLT在这里扮演的是一个高效的HTML骨架生成器,而真正的“活”和“美化”还是交给了CSS和JavaScript。这体现了关注点分离的原则,虽然XSLT本身在&amp;lt;a style="color:#f60; text-decoration:underline;" title="前端" href="https://www.php.cn/zt/15813.html" target="_blank"&amp;gt;前端&amp;lt;/a&amp;gt;领域已经不那么主流,但这种思路在现代框架中依然随处可见。&amp;lt;/p&amp;gt;

以上就是XSLT如何输出HTML?的详细内容,更多请关注php中文网其它相关文章!

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号