繁体   English   中英

如何动态添加gridview

[英]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 找到的其他一些地方:

http://www.dotnetfox.com/articles/create-dynamic-gridview-or-programmatically-create-Asp-Net-gridview-with-dynamic-boundfield-1083.aspx

如何使用asp.net c#并排动态添加gridviews

http://codedisplay.com/runtime-dynamically-creating-gridview-and-bind-data-in-bound-columns-using-asp-net-c-vb-net/

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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM