我正在尝试将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();
}
答案 0 :(得分:0)
我使用更多网格和表格部分解决了我的问题。
我创建了一个主控件并通过代码添加了列。在列中,我放了其他GridView。我选择而不是GridView因为它更容易使用它的列。
我不得不详细说明我的数据源将其拆分为更多列表,但是从现在开始,我将选择另一种结构将我的数据从calc方法传递给可视化方法。
感谢大家的帮助;)