2012-09-12 109 views
1

我想在一个固定的索引绑定一个GridView列于表元素固定索引列表元素,但我得到一个异常时,我执行Grid.DataBind();绑定的GridView列在

找不到字段或属性从 选定的数据源名为'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

'DataField'应该是一个属性名,所以很明显“MISURE [0] .ID”是行不通的,但究竟什么是你想怎么办? –

+0

在列表'Misure'中,我有一个可变数量的元素。我想为每个元素添加五个网格列,并将这些元素的属性数据放入这些列中。 – Pomp

+0

您不要为每个项目添加列,而是为整个列表添加列。添加列之后,您需要将列表绑定到网格。 –

回答

0

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

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

我必须将我的数据源分割成更多的列表,但从现在开始,我会选择另一个结构来将我的数据从calc方法传递给可视化方法。

谢谢大家的帮助;)

+0

你能否包含一些代码片段来详细说明你是如何完成这个的? – Hannele