将转发器与Dictionary <string,list <myclass =“”>&gt; </string,>绑定

时间:2015-03-24 19:01:38

标签: c# nested-repeater

假设我有一个包含以下结构数据的数据表:

收入认证-1000 收入-IT考试完成-1000 Acadmics-Value1-100 Acadmics-Value23-1000 ......等等

我写了一个查询,它将返回一个包含Key作为Revenue and Academics的Dictionary,并在这些键下面包含一个包含所有其他值的通用List。

现在我有一个要求,我必须在其中显示转发器控件 1行wouuld是此词典的关键,并在此键下方所有关联值。

我无法理解如何实现这一点......转发器或其他任何转发器。请帮助设计转发器或任何其他控件并将值绑定到它。提前谢谢。

1 个答案:

答案 0 :(得分:0)

首先,我要感谢@Aybe的回复。

我已经尝试了很多,最终得到了预期的结果。

        <div>
        <table>
            <asp:Repeater ID="Repeater1" runat="server">
                <ItemTemplate>
                    <tr>
                        <td>
                            <%#Eval("Key") %>
                            <div>
                               <asp:Repeater ID="Repeater2" runat="server">
                                   <ItemTemplate>
                                        <asp:Label runat="server" ForeColor="Red" Text='<%#Eval("MetricName") %>'></asp:Label><br />
                                       <asp:Label runat="server" ForeColor="Red" Text='<%#Eval("FiscalYeartarget") %>'></asp:Label><br />
                                   </ItemTemplate>
                               </asp:Repeater>
                            </div>
                        </td>
                    </tr>
                </ItemTemplate>
            </asp:Repeater>
        </table>
    </div>

在C#中 - 我创建了一个如下的字典:

public Dictionary<string, List<custom>> query1;
string connstr = "Data Source=(local);Initial Catalog=t;Integrated Security=True";
    string query = "SELECT * FROM [td]";
    DataTable dTable = new DataTable();

    using (SqlConnection sqlconn = new SqlConnection(connstr))
    {
        sqlconn.Open();
        SqlDataAdapter sqlda = new SqlDataAdapter(query, sqlconn);
        sqlda.Fill(dTable);

        query1 = dTable.AsEnumerable().GroupBy(x => x.Field<string>("HeaderName"))
            .ToDictionary(grp => grp.Key, x => x.Select(y => new custom()
            {
                MetricName = y.Field<string>("MetricName/KPI"),
                FiscalYeartarget = y.Field<double>("FiscalYeartarget").ToString(),
                Status = y.Field<string>("Status"),
                VTF = y.Field<double>("VTF").ToString(),
                VTF_Percent = y.Field<double>("VTF %").ToString(),
                YTDResults = y.Field<double>("YTDResults").ToString(),
                YTDTarget = y.Field<double>("YTDTarget").ToString()
            }).ToList());

        Repeater1.DataSource = query1;
        Repeater1.DataBind();

        var counter = 0;
        foreach (var x in query1)
        {
            Repeater rptr = (Repeater)Repeater1.Controls[counter].FindControl("Repeater2");
            rptr.DataSource = x.Value.ToList();
            rptr.DataBind();
            counter++;
        }
    }

最后是我的自定义类:

public class custom
{
    public string MetricName { get; set; }
    public string FiscalYeartarget { get; set; }
    public string YTDTarget { get; set; }
    public string YTDResults { get; set; }
    public string VTF { get; set; }
    public string VTF_Percent { get; set; }
    public string Status { get; set; }
}