如何在asp.net中动态添加gridview c#

时间:2017-02-27 17:08:14

标签: c# asp.net gridview

大家好我必须在asp.net中动态添加多个gridview。没有gridview在选择的基础上进行处理。 先谢谢

4 个答案:

答案 0 :(得分:2)

如果我没有从标题中理解错误,那么动态添加多个网格视图就意味着想要在运行时从代码中添加网格视图。

由于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 );
} 

希望我能正确理解您的要求,我的解释对您有所帮助。

答案 1 :(得分:0)

我完全赞同@RMadd。所以不是代码编写服务,你应该首先尝试给我们一些东西来看看,并告诉你哪里出错了。

但是,如果你不知道从哪里开始,一种方法是添加所有没有可见性的空网格视图,并根据选择将它们设置为可见。

我对你的模糊问题给出的答案含糊不清。

以下是我在Google-foo中找到的其他一些地方:

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

How to dynamically add gridviews side by side using asp.net c#

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

答案 2 :(得分:0)

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();
    }

答案 3 :(得分:0)



         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);
            }
           
        }