Gridview和objectdatasource的问题

时间:2011-07-05 14:12:21

标签: asp.net gridview objectdatasource

<asp:ObjectDataSource ID="ObjectDataSource1" runat="server" 
           SelectMethod="GetObjects" TypeName="ControlPanelMessages">
       </asp:ObjectDataSource>

我需要的是将两个项目放在一行.. Img和名称应该在同一行。

我如何实现这一目标?

更新..我可以这样做:

DataRow newRow = table.NewRow();

// Set values in the columns:
newRow["Img"] = "NewCompanyImage";
newRow["Img"] = "NewCompanyName";

它会将两个值放在同一行吗?

这就是我所做的:

    public DataSet GetObjects()
{
    DataSet ds = new DataSet();
    DataTable dt = new DataTable();
    var source = from p in CommentsList
                 select new { p.Img, p.Name, p.Comment };
    dt.Columns.Add("User");
    dt.Columns.Add("Comment");

    foreach (var item in source)
    {
        DataRow UserDetailsRow=dt.NewRow();
        UserDetailsRow["User"] = item.Img;
        UserDetailsRow["User"] = item.Name;
        UserDetailsRow["Comment"] = item.Comment;
      //  dt.Rows.Add(new object[] { item.Img, item.Name, item.Comment });
    }
    ds.Tables.Add(dt);
    return ds;
}

这是正确的方法吗?

1 个答案:

答案 0 :(得分:0)

您尚未向数据表中添加任何列,您需要执行

dt.Columns.Add("Img");
在添加行之前,为每个列添加