Pregunta

Estoy atrapado en un problema. Creo que probablemente esté cerca de la solución, pero parece que no puedo llegar allí. Tengo un XMLDOC que está cargado de un proceso almacenado, en un conjunto de datos y el XML se extrae de él (no creo que pueda cambiar ninguna de esta parte). El XML se ve así:

<data>
  <datanode>
    <name>11</name>
    <group>G1</group>
    <value>val1</value>
  </datanode>
  <datanode>
    <name>12</name>
    <group>G1</group>
    <value>val2</value>
  </datanode>  
  <datanode>
<name>21</name>
<group>G2</group>
<value>val1</value>
  </datanode>
  <datanode>
<name>22</name>
<group>G2</group>
<value>val2</value>
  </datanode>
  <datanode>
<name>23</name>
<group>G2</group>
<value>val3</value>
  </datanode>  
  <datanode>
<name>31</name>
<group>G3</group>
<value>val1</value>
  </datanode>
  <datanode>
<name>32</name>
<group>G3</group>
<value>val2</value>
  </datanode>
  <datanode>
<name>33</name>
<group>G3</group>
<value>val3</value>
  </datanode>
  <datanode>
<name>34</name>
<group>G3</group>
<value>val4</value>
  </datanode>
</data>

Necesito usar repetidores anidados para mostrar esta información. Lo que quiero es agruparlo por el nodo "Grupo" y luego mostrar cada uno de los "Datanodes" que pertenecen a ese nodo "Grupo". Entonces se vería algo así en la página:

G1 - has 2 nodes
11 - Val1
12 - Val2

G2 - has 3 nodes
21 - Val1
22 - Val2
23 - Val3

etc

Lo que tengo hasta ahora: default.aspx:

    <asp:Repeater ID="Repeater1" runat="server">

    <ItemTemplate>
        <p>                
            COUNT: <asp:Literal runat="server" ID="Literal3" Text='<%# XPath("count(group)") %>' />                
            <br />Text: <asp:Literal runat="server" ID="Literal4" Text='<%# XPath("text()") %>' />
            <br />Group: <asp:Literal runat="server" ID="Literal2" Text='<%# XPath("group") %>' />
            <br />ID: <asp:Literal runat="server" ID="displayname" Text='<%# XPath("name") %>' />
            <br />VAL: <asp:Literal runat="server" ID="Literal1" Text='<%# XPath("value") %>' />
         </p>            

    </ItemTemplate>

    </asp:Repeater>

Default.aspx.cs

public partial class _Default : System.Web.UI.Page
{
    private XmlNodeList nodelist;

    protected void Page_Load(object sender, EventArgs e)
    {
        XmlDocument doc = new XmlDocument();
        doc.Load(@"C:\development\testforWork\WebApplication1\WebApplication1\data.xml");

        nodelist = doc.SelectNodes("//datanode[not(group=preceding-sibling::datanode/group)]/group");           
        //nodelist = doc.SelectNodes("//datanode[group='G2']");

        Repeater1.DataSource = nodelist;
        Repeater1.DataBind();
    }
}

Puedo hacer que muestren cada DataNode uno tras otro, pero no puedo descubrir cómo anidar los repetidores y hacer la agrupación. Soy nuevo para XPath y repetidores y creo que debo tener algo de brecha en mi conocimiento y simplemente no puedo conectar los puntos (a menos que esté corriendo por el camino equivocado por completo).

Gracias

¿Fue útil?

Solución

Ok, encontré mi solución después de un poco más de experimentación:

<asp:Repeater ID="repManifestNumber" runat="server" DataSource="<%# ManifestDataTemp %>">
                    <ItemTemplate>
                            Manifest Number:
                            <%# CurrentManifestNumber = XPath("manifest_number").ToString() %>                                
                             - <%# XPath("count(..//box_item[manifest_number=" + CurrentManifestNumber + "])")%> Box(s)

                        <div class="showhide">
                                <asp:Repeater ID="repMainfestDetail" runat="server" DataSource='<%# ((XmlNode)Container.DataItem).SelectNodes("..//box_item[manifest_number=" + CurrentManifestNumber + "]") %>'>
                                    <HeaderTemplate>
                                        <table class="orders" id="manifest_<%# CurrentManifestNumber %>">
                                            <tr>
                                                <th>
                                                    Box Number
                                                </th>
                                                <th>
                                                    Date Dispatched
                                                </th>
                                                <th>
                                                    <input type="checkbox" class="checkboxflipflop_local" />
                                                    - Select All
                                                </th>
                                            </tr>
                                            <asp:PlaceHolder ID="itemPlaceholder" runat="server" />
                                    </HeaderTemplate>
                                    <ItemTemplate>
                                        <tr class="odd-table-row">
                                            <td>
                                                <asp:Literal runat="server" ID="litBoxNumber" Text='<%# XPath("box_number") %>' />
                                            </td>
                                            <td>
                                                <asp:Literal runat="server" ID="litErpDispatched" Text='<%# Convert.ToDateTime(XPath("date_dispatched")).ToString("dd/MM/yyyy") %>' />
                                            </td>
                                            <td>
                                                <asp:Literal runat="server" ID="litHiddenXmlNode" Text='<%# ((XmlNode)Container.DataItem).OuterXml %>'
                                                    Visible="false"></asp:Literal>
                                                <asp:CheckBox ID="chkIsReceived" runat="server" Checked="false" CssClass="storecheckbox" />
                                            </td>
                                        </tr>
                                    </ItemTemplate>

                                </asp:Repeater>                                
                        </table>
                        </div>
                    </ItemTemplate>

                </asp:Repeater>

Espero que esto pueda ayudar a alguien más en el futuro (o a mí cuando lo olvide de nuevo).

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top