У меня есть XML, как показано ниже
<Employees>
<Employee>
<ID>100</ID>
<FirstName>Bala</FirstName>
<LastName>Murugan</LastName>
<Dept>Production Support</Dept>
</Employee>
<Employee0>
<ID>101</ID>
<FirstName>Peter</FirstName>
<LastName>Laurence</LastName>
<Dept>Development</Dept>
</Employee0>
<Employee1>
<ID>102</ID>
<FirstName>Rick</FirstName>
<LastName>Anderson</LastName>
<Dept>Sales</Dept>
</Employee1>
</Employees>
Я хотел бы показать одному из этих сотрудников, используя следующий XSLT
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:param name="SLCT"/>
<xsl:template match="/">
<xsl:for-each select="$SLCT">
<div style="border:1px black solid;width:300px;margin:1px">
<div>
<b>Employee ID:</b>
<xsl:value-of select="ID"/>
</div>
<div>
<b>Name:</b>
<xsl:value-of select="FirstName"/>
<xsl:text> </xsl:text>
<xsl:value-of select="LastName"/>
</div>
<div>
<b>Department:</b>
<xsl:value-of select="Dept"/>
</div>
</div>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
проблема с (for-each select = "$ SLCT"), он не принимает параметр из C#.
мой C# код
protected void Page_Load(object sender, EventArgs e)
{
string strXSLTFile = Server.MapPath("EmployeeXSLT.xslt");
string strXMLFile = Server.MapPath("Employess.xml");
XmlReader reader = XmlReader.Create(strXMLFile);
XslCompiledTransform objXSLTransform = new XslCompiledTransform();
objXSLTransform.Load(strXSLTFile);
// Create the XsltArgumentList.
XsltArgumentList argList = new XsltArgumentList();
// Set new value to the parameter
argList.AddParam("SLCT", "", "(//Employee)[1]");
XmlWriter writer = XmlWriter.Create(Server.MapPath("OutPut.xml"));
objXSLTransform.Transform(new XPathDocument(strXMLFile), argList, writer);
//Expression must evaluate to a node-set
writer.Close();
reader.Close();
Xml2.DocumentSource = Server.MapPath("~/test/Employess.xml");
Xml2.TransformSource = Server.MapPath("~/test/OutPut.xml");
Xml2.DataBind();
}
Я получил это исключение, как прокомментировано в коде (// выражение должно вычисляться для набора узлов). Однако, когда я использую «(// Employee) [1]» или «// Employee» непосредственно в файле XSLT вместо использования параметра (SLCT), я получаю нужный результат. Итак, в чем здесь проблема?