1

我正在尝试将 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; }
}

网格视图:

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

方法:

    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();
    }
4

1 回答 1

0

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

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

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

感谢大家的帮助;)

于 2012-09-19T15:39:08.550 回答