XSLT如何输出HTML?

<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>

</div> 元素来完成:</p><div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=’brush:xml;toolbar:false;’><xsl:output method="html" indent="yes"/></pre>

</div><p>这里的 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>method="html"</pre>

</div> 是关键,它告诉处理器按照HTML的规则来序列化输出,比如空元素(如 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><br></pre>

</div>)会输出为 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><br></pre>

</div> 而不是 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><br/></pre>

</div>,并且会处理HTML实体。<div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>indent="yes"</pre>

</div> 则让输出的HTML更易读。</p><p><span>立即学习</span>“<a href=”https://pan.quark.cn/s/cb6835dc7db1″ style=”text-decoration: underline !important; color: blue; font-weight: bolder;” rel=”nofollow” target=”_blank”>前端免费学习笔记(深入)</a>”;</p><p>接着,你需要在XSLT样式表中编写模板(<div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:template</pre>

</div>)。这些模板会根据XPath表达式匹配XML文档中的节点,然后生成相应的HTML结构。</p><p>例如,一个最基本的转换可能长这样:</p><p><strong>XML源文档 (data.xml):</strong></p><div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=’brush:xml;toolbar:false;’><bookstore> <book category="cooking"> <title lang="en">Everyday Italian</title> <author>Giada De Laurentiis</author> <year>2005</year> <price>30.00</price> </book> <book category="web"> <title lang="en">Learning XML</title> <author>Erik T. Ray</author> <year>2003</year> <price>39.95</price> </book></bookstore></pre>

</div><p><strong>XSLT样式表 (transform.xslt):</strong></p><div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=’brush:xml;toolbar:false;’><?xml version=”1.0″ encoding=”UTF-8″?><xsl:stylesheet version=”1.0″xmlns:xsl="http://www.w3.org/1999/XSL/Transform"><xsl:output method="html" indent="yes"/><xsl:template match="/"> <html> <head> <title>我的书店</title> </head> <body> <h1>书店列表</h1> <ul> <xsl:apply-templates select="bookstore/book"/> </ul> </body> </html></xsl:template><xsl:template match="book"> <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></pre>

</div><p><strong>处理结果 (HTML输出):</strong></p><div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=’brush:html;toolbar:false;’><!DOCTYPE html><html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <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></pre>

</div><p>在这个例子中,<div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:template match="/"</pre>

</div> 匹配整个XML文档的根节点,然后生成HTML的 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><html></pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><head></pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><body></pre>

</div> 结构。<div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:apply-templates select="bookstore/book"</pre>

</div> 则会找到所有 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><book></pre>

</div> 节点,并为每个节点应用一个匹配的模板。第二个 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:template match="book"</pre>

</div> 就是为每个 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><book></pre>

</div> 节点生成一个 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><li></pre>

</div> 列表项,并提取其中的 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>title</pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>author</pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>year</pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>price</pre>

</div> 内容。</p><p>这套机制让我觉得XSLT有点像“声明式编程”的早期尝试,你不是告诉<a style=”color:#f60; text-decoration:underline;” title=”计算机” href=”https://www.php.cn/zt/16013.html” target=”_blank”>计算机</a>“一步步怎么做”,而是告诉它“当看到这个结构时,应该变成那个结构”。</p><h3>XSLT在生成HTML时如何处理各种元素和属性?</h3><p>XSLT在生成HTML时,处理元素和属性的方式相当直接,但也需要一些技巧。基本上,任何不在XSLT命名空间(<div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xmlns:xsl="http://www.w3.org/1999/XSL/Transform"</pre>

</div>)内的元素,都会被原样输出到结果文档中。这就是为什么我们可以在 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:template</pre>

</div> 内部直接写 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><html></pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><head></pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><body></pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><h1></pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><ul></pre>

</div>, <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><li></pre>

</div> 等HTML标签。</p><p>对于属性,你可以直接在输出的HTML元素上写死属性,比如 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><a href="index.html"></pre>

</div>。但更多时候,属性值是动态的,需要从XML源数据中提取。这时,我们使用 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:attribute</pre>

</div> 元素。</p><p>例如,如果你想根据XML中的一个属性来设置HTML元素的属性:</p><p><strong>XML:</strong></p><div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=’brush:xml;toolbar:false;’><product id="p101" status="new"> <name>Awesome Gadget</name></product></pre>

</div><p><strong>XSLT:</strong></p><div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=’brush:xml;toolbar:false;’><xsl:template match="product"> <div class="product-item"> <xsl:attribute name="data-id"> <xsl:value-of select="@id"/> </xsl:attribute> <xsl:attribute name="class"> product-item <xsl:value-of select="@status"/> </xsl:attribute> <h2><xsl:value-of select="name"/></h2> </div></xsl:template></pre>

</div><p>这里,我们通过 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:attribute name="data-id"</pre>

</div> 来创建一个 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>data-id</pre>

</div> 属性,其值来自XML的 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>@id</pre>

</div> 属性。注意,<div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>class</pre>

</div> 属性演示了如何拼接静态文本和动态值。</p> <div class=”aritcle_card”> <a class=”aritcle_card_img” href=”/xiazai/code/10454″> <img src=”https://img.php.cn/upload/webcode/000/000/020/176216580836240.jpg” alt=”通吃客零食网整站 for Shopex”> </a> <div class=”aritcle_card_info”> <a href=”/xiazai/code/10454″>通吃客零食网整站 for Shopex</a> <p>第一步】:将安装包中所有的文件夹和文件用ftp工具以二进制方式上传至服务器空间;(如果您不知如何设置ftp工具的二进制方式,可以查看:(http://www.shopex.cn/support/qa/setup.help.717.html)【第二步】:在浏览器中输入 http://您的商店域名/install 进行安装界面进行安装即可。【第二步】:登录后台,工具箱里恢复数据管理后台是url/sho</p> <div class=””> <img src=”/static/images/card_xiazai.png” alt=”通吃客零食网整站 for Shopex”> <span>0</span> </div> </div> <a href=”/xiazai/code/10454″ class=”aritcle_card_btn”> <span>查看详情</span> <img src=”/static/images/cardxiayige-3.png” alt=”通吃客零食网整站 for Shopex”> </a> </div> <p>此外,还有 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:element</pre>

</div> 可以动态生成元素名称,虽然在生成固定HTML结构时不如直接写HTML标签常用,但在某些需要根据XML数据决定输出哪个HTML标签的场景下,它就很有用了。比如,如果XML里有个 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><level></pre>

</div> 节点决定输出 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><h1></pre>

</div> 还是 <div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><h2></pre>

</div>,<div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”>xsl:element</pre>

</div> 就能派上用场。但话说回来,对于日常的HTML输出,直接嵌入HTML标签通常更直观、更易读。</p><h3>XSLT转换HTML时如何处理特殊字符和编码问题?</h3><p>处理特殊字符和编码是任何文本处理任务中都绕不开的话题,XSLT也不例外。当XSLT将XML数据转换为HTML时,它会默认对一些HTML的特殊字符进行转义,以确保输出的HTML是格式良好且安全的。例如,<div class=”code” style=”position:relative; padding:0px; margin:0px;”><pre class=”brush:php;toolbar:false;”><</pre>

&lt;/div&gt; 会被转义为 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;<&lt;/pre&gt;

&lt;/div&gt;,&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&gt;&lt;/pre&gt;

&lt;/div&gt; 会变成 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;>&lt;/pre&gt;

&lt;/div&gt;,&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&&lt;/pre&gt;

&lt;/div&gt; 会变成 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&&lt;/pre&gt;

&lt;/div&gt;。这是为了防止XML数据中的内容被&lt;a style=”color:#f60; text-decoration:underline;” title=”浏览器” href=”https://www.php.cn/zt/16180.html” target=”_blank”&gt;浏览器&lt;/a&gt;误解析为HTML标签或实体。&lt;/p&gt;&lt;p&gt;然而,有时候你可能希望某些内容 &lt;em&gt;不被&lt;/em&gt; 转义。最典型的例子就是当XML数据本身就包含了一段HTML片段,你希望这段HTML能直接插入到输出中,而不是被转义。这时,就需要用到 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;disable-output-escaping=”yes”&lt;/pre&gt;

&lt;/div&gt; 属性。这个属性可以加在 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;xsl:value-of&lt;/pre&gt;

&lt;/div&gt; 或 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;xsl:text&lt;/pre&gt;

&lt;/div&gt; 元素上。&lt;/p&gt;&lt;p&gt;例如:&lt;/p&gt;&lt;p&gt;&lt;strong&gt;XML:&lt;/strong&gt;&lt;/p&gt;&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=’brush:xml;toolbar:false;’&gt;&lt;content&gt; This is some rich text.&lt;/content&gt;&lt;/pre&gt;

&lt;/div&gt;&lt;p&gt;&lt;strong&gt;XSLT (错误示范,默认转义):&lt;/strong&gt;&lt;/p&gt;&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=’brush:xml;toolbar:false;’&gt;&lt;p&gt;&lt;xsl:value-of select=”content”/&gt;&lt;/p&gt;&lt;!– 输出: &lt;p&gt;This is some rich text.&lt;/p&gt; –&gt;&lt;/pre&gt;

&lt;/div&gt;&lt;p&gt;&lt;strong&gt;XSLT (正确处理,不转义):&lt;/strong&gt;&lt;/p&gt;&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=’brush:xml;toolbar:false;’&gt;&lt;p&gt;&lt;xsl:value-of select=”content” disable-output-escaping=”yes”/&gt;&lt;/p&gt;&lt;!– 输出: &lt;p&gt;This is some &lt;strong&gt;rich&lt;/strong&gt; text.&lt;/p&gt; –&gt;&lt;/pre&gt;

&lt;/div&gt;&lt;p&gt;需要注意的是,&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;disable-output-escaping&lt;/pre&gt;

&lt;/div&gt; 的使用应该非常谨慎,因为它可能会引入安全漏洞(如XSS攻击),如果XML源数据不可信,不建议随意使用。它本质上是告诉处理器“相信我,这段内容是安全的,直接输出”。&lt;/p&gt;&lt;p&gt;至于编码问题,&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;xsl:output&lt;/pre&gt;

&lt;/div&gt; 元素上的 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;encoding&lt;/pre&gt;

&lt;/div&gt; 属性可以用来指定输出HTML的字符编码,比如 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;encoding=”UTF-8″&lt;/pre&gt;

&lt;/div&gt;。大多数现代Web应用都推荐使用UTF-8。如果XML源文档有声明编码,XSLT处理器通常会尊重它,并在转换过程中保持一致。如果输出HTML没有明确指定编码,浏览器可能会根据HTTP头或HTML的 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;meta charset=”…”&gt;&lt;/pre&gt;

&lt;/div&gt; 标签来猜测。因此,在HTML的 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;head&gt;&lt;/pre&gt;

&lt;/div&gt; 部分加入 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;meta charset=”UTF-8″&gt;&lt;/pre&gt;

&lt;/div&gt; 是一个良好的实践,确保浏览器正确解析字符。我个人习惯总是在 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;xsl:output&lt;/pre&gt;

&lt;/div&gt; 和 HTML 的 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;meta&lt;/pre&gt;

&lt;/div&gt; 标签里都写上 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;UTF-8&lt;/pre&gt;

&lt;/div&gt;,这样能最大程度地避免乱码问题。&lt;/p&gt;&lt;h3&gt;如何在XSLT生成的HTML中引入CSS和JavaScript?&lt;/h3&gt;&lt;p&gt;在XSLT生成的HTML中引入CSS和JavaScript,其实和在普通HTML文件中引入它们没有本质区别。XSLT的任务只是“组装”出HTML结构,至于这个结构内部包含了什么链接或脚本,它并不会特别对待。&lt;/p&gt;&lt;p&gt;最常见的方法就是通过在XXSLT模板中直接输出相应的HTML标签:&lt;/p&gt;&lt;ol&gt;&lt;li&gt;&lt;p&gt;&lt;strong&gt;引入CSS样式表:&lt;/strong&gt;你可以在HTML的 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;head&gt;&lt;/pre&gt;

&lt;/div&gt; 部分输出 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;link&gt;&lt;/pre&gt;

&lt;/div&gt; 标签,指向你的CSS文件。&lt;/p&gt;&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=’brush:xml;toolbar:false;’&gt;&lt;xsl:template match=&quot;/&quot;&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;我的页面&lt;/title&gt; &lt;link rel=”stylesheet” type=”text/css” href=”/static/css/styles.css”/&gt; &lt;!– 也可以引入外部CDN的CSS –&gt; &lt;link rel=”stylesheet” href=”https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css”/&gt; &lt;/head&gt; &lt;body&gt; &lt;!– … content … –&gt; &lt;/body&gt; &lt;/html&gt;&lt;/xsl:template&gt;&lt;/pre&gt;

&lt;/div&gt;&lt;/li&gt;&lt;li&gt;&lt;p&gt;&lt;strong&gt;引入JavaScript脚本:&lt;/strong&gt;同样,在HTML的 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;head&gt;&lt;/pre&gt;

&lt;/div&gt; 或 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;body&gt;&lt;/pre&gt;

&lt;/div&gt; 结束标签之前,输出 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;script&gt;&lt;/pre&gt;

&lt;/div&gt; 标签。&lt;/p&gt;&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=’brush:xml;toolbar:false;’&gt;&lt;xsl:template match=&quot;/&quot;&gt; &lt;html&gt; &lt;head&gt; &lt;!– … CSS … –&gt; &lt;/head&gt; &lt;body&gt; &lt;!– … content … –&gt; &lt;script src=”/static/js/main.js”&gt;&lt;/script&gt; &lt;!– 也可以引入外部CDN的JS –&gt; &lt;script src=”https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js”&gt;&lt;/script&gt; &lt;!– 内联脚本 –&gt; &lt;script&gt; // 你的JavaScript代码 document.addEventListener(‘DOMContentLoaded’, function() { console.log(‘页面已加载完毕!’); }); &lt;/script&gt; &lt;/body&gt; &lt;/html&gt;&lt;/xsl:template&gt;&lt;/pre&gt;

&lt;/div&gt;&lt;p&gt;如果JavaScript代码需要动态地从XML数据中获取值,你可以在 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;script&gt;&lt;/pre&gt;

&lt;/div&gt; 标签内部使用 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;xsl:value-of&lt;/pre&gt;

&lt;/div&gt; 来插入这些值,或者生成带有 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;data-&lt;/pre&gt;

&lt;/div&gt; 属性的HTML元素,然后JavaScript去读取这些属性。&lt;/p&gt;&lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=’brush:xml;toolbar:false;’&gt;&lt;xsl:template match=”product”&gt; &lt;div class=”product-card” data-product-id=”{@id}” data-price=”{@price}”&gt; &lt;h2&gt;&lt;xsl:value-of select=”name”/&gt;&lt;/h2&gt; &lt;button onclick=”addToCart(this)”&gt;添加到购物车&lt;/button&gt; &lt;/div&gt;&lt;/xsl:template&gt;&lt;!– 在HTML的某个地方,比如body底部 –&gt;&lt;script&gt; function addToCart(button) { const productId = button.closest(‘.product-card’).dataset.productId; const price = button.closest(‘.product-card’).dataset.price; console.log(`添加产品ID: ${productId}, 价格: ${price} 到购物车`); // 实际的购物车逻辑 }&lt;/script&gt;&lt;/pre&gt;

&lt;/div&gt;&lt;/li&gt;&lt;/ol&gt;&lt;p&gt;这种方式的优点是直观且符合Web标准。XSLT只负责把 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;link&gt;&lt;/pre&gt;

&lt;/div&gt; 和 &lt;div class=”code” style=”position:relative; padding:0px; margin:0px;”&gt;&lt;pre class=”brush:php;toolbar:false;”&gt;&lt;script&gt;&lt;/pre&gt;

&lt;/div&gt; 标签“打印”出来,后续的资源加载和执行完全由浏览器负责。在我看来,XSLT在这里扮演的是一个高效的HTML骨架生成器,而真正的“活”和“美化”还是交给了CSS和JavaScript。这体现了关注点分离的原则,虽然XSLT本身在&lt;a style=”color:#f60; text-decoration:underline;” title=”前端” href=”https://www.php.cn/zt/15813.html” target=”_blank”&gt;前端&lt;/a&gt;领域已经不那么主流,但这种思路在现代框架中依然随处可见。&lt;/p&gt;

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1430844.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 04:01:24
下一篇 2025年12月17日 04:01:34

相关推荐

  • CSS mask属性无法获取图片:为什么我的图片不见了?

    CSS mask属性无法获取图片 在使用CSS mask属性时,可能会遇到无法获取指定照片的情况。这个问题通常表现为: 网络面板中没有请求图片:尽管CSS代码中指定了图片地址,但网络面板中却找不到图片的请求记录。 问题原因: 此问题的可能原因是浏览器的兼容性问题。某些较旧版本的浏览器可能不支持CSS…

    2025年12月24日
    900
  • 如何用dom2img解决网页打印样式不显示的问题?

    用dom2img解决网页打印样式不显示的问题 想将网页以所见即打印的的效果呈现,需要采取一些措施,特别是在使用了bootstrap等大量采用外部css样式的框架时。 问题根源 在常规打印操作中,浏览器通常会忽略css样式等非必要的页面元素,导致打印出的结果与网页显示效果不一致。这是因为打印机制只识别…

    2025年12月24日
    800
  • 如何用 CSS 模拟不影响其他元素的链接移入效果?

    如何模拟 css 中链接的移入效果 在 css 中,模拟移入到指定链接的效果尤为复杂,因为链接的移入效果不影响其他元素。要实现这种效果,最简单的方法是利用放大,例如使用 scale 或 transform 元素的 scale 属性。下面提供两种方法: scale 属性: .goods-item:ho…

    2025年12月24日
    700
  • Uniapp 中如何不拉伸不裁剪地展示图片?

    灵活展示图片:如何不拉伸不裁剪 在界面设计中,常常需要以原尺寸展示用户上传的图片。本文将介绍一种在 uniapp 框架中实现该功能的简单方法。 对于不同尺寸的图片,可以采用以下处理方式: 极端宽高比:撑满屏幕宽度或高度,再等比缩放居中。非极端宽高比:居中显示,若能撑满则撑满。 然而,如果需要不拉伸不…

    2025年12月24日
    400
  • PC端H5项目如何实现适配:流式布局、响应式设计和两套样式?

    PC端的适配方案及PC与H5兼顾的实现方案探讨 在开发H5项目时,常用的屏幕适配方案是postcss-pxtorem或postcss-px-to-viewport,通常基于iPhone 6标准作为设计稿。但对于PC端网项目,处理不同屏幕大小需要其他方案。 PC端屏幕适配方案 PC端屏幕适配一般采用流…

    2025年12月24日
    300
  • CSS 元素设置 10em 和 transition 后为何没有放大效果?

    CSS 元素设置 10em 和 transition 后为何无放大效果? 你尝试设置了一个 .box 类,其中包含字体大小为 10em 和过渡持续时间为 2 秒的文本。当你载入到页面时,它没有像 YouTube 视频中那样产生放大效果。 原因可能在于你将 CSS 直接写在页面中 在你的代码示例中,C…

    2025年12月24日
    400
  • 如何实现类似横向U型步骤条的组件?

    横向U型步骤条寻求替代品 希望找到类似横向U型步骤条的组件或 CSS 实现。 潜在解决方案 根据给出的参考图片,类似的组件有: 图片所示组件:图片提供了组件的外观,但没有提供具体的实现方式。参考链接:提供的链接指向了 SegmentFault 上的另一个问题,其中可能包含相关的讨论或解决方案建议。 …

    2025年12月24日
    800
  • 如何让小说网站控制台显示乱码,同时网页内容正常显示?

    如何在不影响用户界面的情况下实现控制台乱码? 当在小说网站上下载小说时,大家可能会遇到一个问题:网站上的文本在网页内正常显示,但是在控制台中却是乱码。如何实现此类操作,从而在不影响用户界面(UI)的情况下保持控制台乱码呢? 答案在于使用自定义字体。网站可以通过在服务器端配置自定义字体,并通过在客户端…

    2025年12月24日
    800
  • 如何优化CSS Grid布局中子元素排列和宽度问题?

    css grid布局中的优化问题 在使用css grid布局时可能会遇到以下问题: 问题1:无法控制box1中li的布局 box1设置了grid-template-columns: repeat(auto-fill, 20%),这意味着容器将自动填充尽可能多的20%宽度的列。当li数量大于5时,它们…

    2025年12月24日
    800
  • SASS 中的 Mixins

    mixin 是 css 预处理器提供的工具,虽然它们不是可以被理解的函数,但它们的主要用途是重用代码。 不止一次,我们需要创建多个类来执行相同的操作,但更改单个值,例如字体大小的多个类。 .fs-10 { font-size: 10px;}.fs-20 { font-size: 20px;}.fs-…

    2025年12月24日
    000
  • 如何在地图上轻松创建气泡信息框?

    地图上气泡信息框的巧妙生成 地图上气泡信息框是一种常用的交互功能,它简便易用,能够为用户提供额外信息。本文将探讨如何借助地图库的功能轻松创建这一功能。 利用地图库的原生功能 大多数地图库,如高德地图,都提供了现成的信息窗体和右键菜单功能。这些功能可以通过以下途径实现: 高德地图 JS API 参考文…

    2025年12月24日
    400
  • 如何使用 scroll-behavior 属性实现元素scrollLeft变化时的平滑动画?

    如何实现元素scrollleft变化时的平滑动画效果? 在许多网页应用中,滚动容器的水平滚动条(scrollleft)需要频繁使用。为了让滚动动作更加自然,你希望给scrollleft的变化添加动画效果。 解决方案:scroll-behavior 属性 要实现scrollleft变化时的平滑动画效果…

    2025年12月24日
    000
  • CSS mask 属性无法加载图片:浏览器问题还是代码错误?

    CSS mask 属性请求图片失败 在使用 CSS mask 属性时,您遇到了一个问题,即图片没有被请求获取。这可能是由于以下原因: 浏览器问题:某些浏览器可能在处理 mask 属性时存在 bug。尝试更新到浏览器的最新版本。代码示例中的其他信息:您提供的代码示例中还包含其他 HTML 和 CSS …

    2025年12月24日
    000
  • 如何为滚动元素添加平滑过渡,使滚动条滑动时更自然流畅?

    给滚动元素平滑过渡 如何在滚动条属性(scrollleft)发生改变时为元素添加平滑的过渡效果? 解决方案:scroll-behavior 属性 为滚动容器设置 scroll-behavior 属性可以实现平滑滚动。 html 代码: click the button to slide right!…

    2025年12月24日
    500
  • 如何用 CSS 实现链接移入效果?

    css 中实现链接移入效果的技巧 在 css 中模拟链接的移入效果可能并不容易,因为它们不会影响周围元素。但是,有几个方法可以实现类似的效果: 1. 缩放 最简单的方法是使用 scale 属性,它会放大元素。以下是一个示例: 立即学习“前端免费学习笔记(深入)”; .goods-item:hover…

    2025年12月24日
    000
  • 网页使用本地字体:为什么 CSS 代码中明明指定了“荆南麦圆体”,页面却仍然显示“微软雅黑”?

    网页中使用本地字体 本文将解答如何将本地安装字体应用到网页中,避免使用 src 属性直接引入字体文件。 问题: 想要在网页上使用已安装的“荆南麦圆体”字体,但 css 代码中将其置于第一位的“font-family”属性,页面仍显示“微软雅黑”字体。 立即学习“前端免费学习笔记(深入)”; 答案: …

    2025年12月24日
    000
  • 如何选择元素个数不固定的指定类名子元素?

    灵活选择元素个数不固定的指定类名子元素 在网页布局中,有时需要选择特定类名的子元素,但这些元素的数量并不固定。例如,下面这段 html 代码中,activebar 和 item 元素的数量均不固定: *n *n 如果需要选择第一个 item元素,可以使用 css 选择器 :nth-child()。该…

    2025年12月24日
    200
  • 如何用 CSS 实现类似卡券的缺口效果?

    类似卡券的布局如何实现 想要实现类似卡券的布局,可以使用遮罩(mask)来实现缺口效果。 示例代码: .card { -webkit-mask: radial-gradient(circle at 20px, #0000 20px, red 0) -20px;} 效果: 立即学习“前端免费学习笔记(…

    2025年12月24日
    000
  • 如何用纯代码实现自定义宽度和间距的虚线边框?

    自定义宽度和间距的虚线边框 提问: 如何创建一个自定义宽度和间距的虚线边框,如下图所示: 元素宽度:8px元素高度:1px间距:2px圆角:4px 解答: 传统的解决方案通常涉及使用 border-image 引入切片的图片来实现。但是,这需要引入外部资源。本解答将提供一种纯代码的方法,使用 svg…

    2025年12月24日
    000
  • PC端、PC兼响应式H5项目,如何选择最佳适配方案?

    多屏适配:PC端、PC兼响应式H5项目解决方案 针对PC端的网页适配,业界普遍采用以下方案: 流媒体查询:根据设备屏幕宽度应用不同的样式表,实现不同屏幕尺寸的适配。栅格系统:将布局划分为多个网格,根据屏幕宽度调整网格的显示和隐藏,实现自适应布局。 一般情况下,设计师设计PC页面时,会以特定像素宽度为…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信