Xslt 如何从html或javascript提供样式表变量值
我的问题是关于在使用xsl的客户端上呈现。这已经在IE中起作用了,但我想让它在firefox上起作用 首先,样式表(variablexsl.xsl)这里唯一的特殊之处是Xslt 如何从html或javascript提供样式表变量值,xslt,selectsinglenode,xsl-stylesheet,xsl-variable,Xslt,Selectsinglenode,Xsl Stylesheet,Xsl Variable,我的问题是关于在使用xsl的客户端上呈现。这已经在IE中起作用了,但我想让它在firefox上起作用 首先,样式表(variablexsl.xsl)这里唯一的特殊之处是 Well XSLT有一个定义良好的机制将外部参数传递给XSLT样式表,即通过在样式表中放置顶级xsl:param元素来定义外部参数的名称(以及默认值,如果需要)然后在运行转换之前,使用XSLT处理器的API设置参数 对于Mozilla、Opera、Safari和Chrome,您可以使用相同的API: 对于使用MSXML的IE,
Well XSLT有一个定义良好的机制将外部参数传递给XSLT样式表,即通过在样式表中放置顶级
xsl:param
元素来定义外部参数的名称(以及默认值,如果需要)然后在运行转换之前,使用XSLT处理器的API设置参数
对于Mozilla、Opera、Safari和Chrome,您可以使用相同的API:
对于使用MSXML的IE,您需要使用相应的MSXML API:。Well XSLT有一个定义良好的机制将外部参数传递给XSLT样式表,即通过在样式表中放置顶级
xsl:param
元素来定义外部参数的名称(以及默认值,如果需要)然后在运行转换之前,使用XSLT处理器的API设置参数
对于Mozilla、Opera、Safari和Chrome,您可以使用相同的API:
对于使用MSXML的IE,您需要使用相应的MSXML API:。注意,您不需要为
transformToFragment
创建临时文档;只需执行例如var targetEl=document.getElementById(“片段”);var newFragment=processor.transformToFragment(xmlholder,targetEl.ownerDocument);targetEl.appendChild(newFragment)
。请注意,不需要为transformToFragment
创建临时文档;只需执行例如var targetEl=document.getElementById(“片段”);var newFragment=processor.transformToFragment(xmlholder,targetEl.ownerDocument);targetEl.appendChild(newFragment)代码>。
<?xml version="1.0" encoding="UTF-8" ?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<xsl:variable name="module" select="string('RES')"/>
<table cellpadding="0" cellspacing="0" border="0" ID="randomID">
<tr>
<xsl:choose>
<xsl:when test="$module = 'EDU'">
<td>EDU was supplied..</td>
</xsl:when>
</xsl:choose>
</tr>
<tr>
<xsl:choose>
<xsl:when test="$module = 'RES'">
<td>RES was supplied..</td>
</xsl:when>
</xsl:choose>
</tr>
</table>
</xsl:template>
</xsl:stylesheet>
<html>
<head>
<script>
function selectmTab(args) {
var xml = loadXMLDoc("variabledata.xml"); //ajax call and holds the responseXML. variabledata.xml is empty
var xsl = loadXMLDoc("variablexsl.xsl"); //ajax call and holds the responseXML
var ss2 = xsl.selectSingleNode('//xsl:variable/@select');
ss2.value = "string('" + args + "')";
document.getElementById("xsltest").innerHTML = xml.transformNode(xsl);
}
</script>
</head>
<body onload="displayResult()">
<div>
<input type="button" value="EDU" onclick="selectmTab('EDU');" />
<input type="button" value="RES" onclick="selectmTab('RES');" />
</div>
<div id="xsltest"></div>
</body>
</html>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:param name="winnersOnly">RES</xsl:param>
<xsl:template match="/">
<xsl:variable name="module" select="$winnersOnly"/>
var processor = new XSLTProcessor();
xslholder = loadXMLDoc("styles.xsl");
processor.importStylesheet(xslholder);
processor.setParameter(null, "winnersOnly", "EDU"); //setting the value here
xmlholder = loadXMLDoc("data.xml");
var ownerDocument = document.implementation.createDocument("", "test", null);
var newFragment = processor.transformToFragment(xmlholder, ownerDocument);
document.getElementById("fragment").appendChild(newFragment);