将GridView列绑定到固定索引处的List元素

时间:2012-09-12 10:32:19

标签: c# data-binding gridview

我正在尝试将GridView列绑定到固定索引处的List元素,但是当我执行Grid.DataBind();时出现异常:

  

无法从中找到名为“Misure [0] .ID”的字段或属性   选定的数据来源。

自定义类:

public partial class RowTabellaConcentrazioneGiornaliera
{
    public DateTime Data { get; set; }
    public string DataString { get; set; }
    public List<MisuraConcentrazione> Misure { get; set; }

}

public partial class MisuraConcentrazione
{
    public double MediaOraTQ { get; set; }
    public double MediaOraNorm { get; set; }
    public double ID { get; set; }
    public string IVTQ { get; set; }
    public string IVN { get; set; }
    public string MeasureCod { get; set; }
    public string DescrizioneParametro { get; set; }
}

GridView的:

    <asp:GridView ID="GridDatiConcentrazione" runat="server" AutoGenerateColumns="false" >
        <Columns>
            <asp:BoundField  DataField="DataString" HeaderText="Ora" ItemStyle-Width="50px" ItemStyle-HorizontalAlign="Center" />
        </Columns>
    </asp:GridView>

Mehod:

    protected void SetTabellaSintesiConcentrazioniGiornaliere(BFStat.BFStat _BFStat1, GridView Grid)
    {
        //Carica Griglia di sintesi concentrazione
        List<RowTabellaConcentrazioneGiornaliera> y = _BFStat1.GetConcentrazioniOrarie();

        int i = 0;
        foreach (MisuraConcentrazione riga in y[0].Misure)
        {
            BoundField NewColonnaID = new BoundField();
            NewColonnaID.HeaderText = "Ind. Disp.";
            NewColonnaID.DataField = "Misure[" + i + "].ID";
            Grid.Columns.Add(NewColonnaID);

            BoundField NewColonnaValueTQ = new BoundField();
            NewColonnaValueTQ.HeaderText = "Valore TQ";
            NewColonnaValueTQ.DataField = "Misure[" + i + "].MediaOraTQ";
            Grid.Columns.Add(NewColonnaValueTQ);

            BoundField NewColonnaIVTQ = new BoundField();
            NewColonnaIVTQ.HeaderText = "Validità TQ";
            NewColonnaIVTQ.DataField = "Misure[" + i + "].IVTQ";
            Grid.Columns.Add(NewColonnaIVTQ);

            BoundField NewColonnaValueN = new BoundField();
            NewColonnaValueN.HeaderText = "Valore N";
            NewColonnaValueN.DataField = "Misure[" + i + "].MediaOraNorm";
            Grid.Columns.Add(NewColonnaValueN);

            BoundField NewColonnaIVN = new BoundField();
            NewColonnaIVN.HeaderText = "Validità N";
            NewColonnaIVN.DataField = "Misure[" + i + "].IVN";
            Grid.Columns.Add(NewColonnaIVN);

            i++;
        }

        Grid.DataSource = y;
        Grid.DataBind();
    }

1 个答案:

答案 0 :(得分:0)

我使用更多网格和表格部分解决了我的问题。

我创建了一个主控件并通过代码添加了列。在列中,我放了其他GridView。我选择而不是GridView因为它更容易使用它的列。

我不得不详细说明我的数据源将其拆分为更多列表,但是从现在开始,我将选择另一种结构将我的数据从calc方法传递给可视化方法。

感谢大家的帮助;)