[英]How to dynamically add gridview
我必须在ASP.net中动态添加多个gridview。没有gridview是根据选择生成的。
如果我没有从标题中理解错误,动态添加多个网格视图意味着要在运行时从代码后面添加网格视图。
由于 GridView 是 ASP.NET C# 中的一个类,我们可以像其他类对象一样创建它的对象并设置其属性,如下所示:
GridView objGV = new GridView();
objGV .AutoGenerateColumns = false;
并且可以从代码中添加不同类型的列,如 BoundField 和 TemplateField 如下所示:
BoundField field = new BoundField();
field.HeaderText = "Column Header";
field.DataField = Value;
objGV .Columns.Add(field);
最后可以在任何容器控件(如面板)下的 .aspx 上添加此网格视图对象。
PanelId.Controls.Add(objGV );
要添加多个网格实例,只需在循环中迭代上面的代码,例如:
for(int i=0;i<yourConditionCount;i++)
{
GridView objGV = new GridView();
objGV.ID="GV"+i; // ID of each grid view must be unique
// your code logic to set properties and events for grid view
PanelId.Controls.Add(objGV );
}
希望我正确理解您的要求,我的解释会对您有所帮助。
我完全同意@RMadd。 SO 不是代码编写服务,您应该首先尝试给我们一些东西来查看并告诉您哪里出错了。
但是,如果您不知道从哪里开始,一种方法是添加所有不可见的空网格视图,并根据选择将它们设置为可见。
对于你这个含糊不清的问题,我所能给出的答案是含糊不清的。
以下是我使用 Google-foo 找到的其他一些地方:
private void BindDynaicGrd()
{
//instance of a datatable
DataTable dt = new DataTable();
//instance of a datarow
DataRow drow;
//creating two datacolums dc1 and dc2
DataColumn dc1 = new DataColumn("Code", typeof(string));
DataColumn dc2 = new DataColumn("Name", typeof(string));
//adding datacolumn to datatable
dt.Columns.Add(dc1);
dt.Columns.Add(dc2);
if (grd.Rows.Count > 0)
{
foreach (GridViewRow gvr in grdSites.Rows)
{
CheckBox chk_Single = (CheckBox)gvr.FindControl("chkSingle");
if (chk_Single.Checked == true)
{
Label lbl_Code = (Label)gvr.FindControl("lblCode");
Label lbl_Name = (Label)gvr.FindControl("lblName");
//instance of a datarow
drow = dt.NewRow();
//add rows to datatable
//add Column values
drow = dt.NewRow();
drow["Code"] = lbl_Code.Text;
drow["Name"] = lbl_Name.Text.ToString();
dt.Rows.Add(drow);
}
}
}
//set gridView Datasource as dataTable dt.
gridcl.DataSource = dt;
//Bind Datasource to gridview
gridcl.DataBind();
}
<asp:Panel ID="Panel1" runat="server"> </asp:Panel>
DataSet ds = new DataSet();
ds = obj.GetMedicalGridWithAge(MphID, ProductCode);
if(ds.Tables.Count > 0)
{
if (ds.Tables[1].Rows.Count > 0)
{
for (int i = 0; i < ds.Tables.Count; i++)
{
GridView gv = new GridView();
gv.ID = "gv" + (i + 1);
gv.DataSource = ds.Tables[i];
gv.DataBind();
Panel1.Controls.Add(gv);
Label newLine = new Label(); newLine.Text = "<br/>";
Panel1.Controls.Add(newLine);
}
}
else
{
GridView gv = new GridView();
gv.ID = "gv" ;
gv.DataSource = null;
gv.DataBind();
Panel1.Controls.Add(gv);
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.