簡體   English   中英

使用函數檢索節點集時如何顯示它們?

[英]How can you display values within a node-set when retrieving them using a function?

我有一個名為FourColumnTable的樣式表,我想用作表模板。 現在看起來像這樣,並使用下面顯示的xml:

<?xml version="1.0" encoding="iso-8859-1"?>
<xsl:stylesheet xmlns:xsl"http://www.w3.org/1999/XSL/Transform" version="2.0">

    <xsl:template name="FourColumnTable">
        <xsl:param name="rows" />

        <table>
            <tbody>
                <tr>
                    <td>Name</td>
                    <td>Age</td>
                    <td>Name</td>
                    <td>Age</td>
                </tr>
            </tbody>
        </table>

        <xsl:variable name="itemCount" select="count($rows/*)" />

        <xsl:if test="$itemCount &gt; 1">
            <xsl:for-each select="$rows/MyTableData">
                <table>
                    <tbody>
                        <tr>
                            <td><xsl:value-of select="name" /></td>
                            <td><xsl:value-of select="age" /></td>
                            <td>blank for now</td>
                            <td>blank for now</td>
                        </tr>
                    </tbody>
                </table>
            </xsl:for-each>
        </xsl:if>
    </xsl:template>
</xsl:stylesheet>

使用返回一些xml作為字符串的函數來檢索數據。 xml看起來像這樣:

<MyDataSet>
  <MyTableData>
    <name>Bob</name>
    <age>25</age>
  </MyTableData>
  <MyTableData>
    <name>Karen</name>
    <age>36</age>
  </MyTableData>
  <MyTableData>
    <name>Frank</name>
    <age>58</age>
  </MyTableData>
</MyDataSet>

我有一個目前可以使用的電子郵件模板,現在我想將此表放入其中。 因此,目前我正在執行以下操作:

<xsl:template name="CustomerData">
  <xsl:call-template name="FourColumnTable">
    <xsl:with-param name="rows" select="msxml:node-set(myFunctions:GetCustomerData())" />
  </xsl:call-template>
</xsl:template>

目前,這似乎創建了一個節點集,但是當我嘗試在for-each使用它時,它不顯示任何值。 我試過刪除if statement ,然后執行以下操作:

  • 對於for-each select語句,將其更改為“ $ rows / MyDataSet / *”。
  • 對於for-each select語句,將其更改為“ $ rows / MyDataSet / MyTableData”。
  • 對於for-each select語句,將其更改為“ $ rows / node()”,然后在“ value-of”的select語句的第一列中添加“ $ rows / node()”。 這將根據xml顯示所有數據,因此我知道$ rows至少具有數據。

我已經嘗試了上述方法的變體,但是這些似乎是值得一提的主要測試。 我不明白的是為什么它將返回所有數據,但是我無法遍歷特定節點(MyTableData節點)。 請幫助。

更新

這是我的函數GetCustomerData()

public string GetCustomerData()
{
    var sb = new StringBuilder();
    var xmlDoc = new XmlDocument();

    xmlDoc.LoadXml(this.GetAllCustomerData());

    var nodeList = xmlDoc.SelectNodes("/MyTableData");

    if (nodeList != null && nodeList.Count > 0)
    {
        foreach (XmlNode node in nodeList)
        {
            sb.Append(node.InnerText + EnvironmentNewLine);
        }
    }

    return sb.ToString();
}

我猜想這需要返回XmlDocument嗎? 但是,我的GetAllCustomerData方法返回的值比我需要的要多得多,這就是為什么我選擇所需的節點的原因。 我可以將此XmlNodeList轉換為XmlDocument嗎?

更新2

我選擇更改函數以按原樣返回xml文檔,然后在表模板中更改在foreach語句中迭代的節點,如下所示:

public XmlDocument GetCustomerData()
{
    var xmlDoc = new XmlDocument(); 
    xmlDoc.LoadXml(this.GetAllCustomerData());

    return xmlDoc;
}

這使我可以迭代所需的內容。

看來您的自定義函數沒有返回xml文檔或文檔片段,它可能只是一個字符串,但無法看到我不確定的函數。

換句話說,您具有

<xsl:param name="rows">&lt;MyDataSet&gt;Data&lt;/MyDataSet&gt;</xsl:param>

代替

<xsl:param name="rows"><MyDataSet>Data</MyDataSet></xsl:param>

而且您不能像XML那樣處理,因為不是,它只是標記。 在其上調用節點集不會將其解析為XML,而是將其轉換為一組一個文本節點。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM