In
some complex scenarios developers need to create runtime GridView
dynamically. So obviously developers need to create dynamic columns for
dynamic gridviews. Here in this article I will explain how one can
develop or implement runtime dynamically create bound column as well as
template column of a GridView control and also how to bind data into
the dynamically created GridView. For simplicity here I use a datatable
but you can bind data from database as well. Here I also showed how
developers can write dynamic event handler for dynamically created
button within the template column. The output will be:
Creating
bound column is easier than template column because if you want to add
dynamic template column in your GridView then you must implement
ITemplate interface. When you instantiate the implemented object then it
will automatically call the "InstantiateIn" method. To implement my
example first add a class in your project and named it
"TemplateHandler". Then copy the code sample:
using System;
using System.Web.UI;
using System.Web.UI.WebControls;
public class TemplateHandler : ITemplate
{
void ITemplate.InstantiateIn(Control container)
{
Button cmd = new Button();
cmd.ID = "cmd";
cmd.Text = "HI";
cmd.Click += new EventHandler(Dynamic_Method);
container.Controls.Add(cmd);
}
protected void Dynamic_Method(object sender, EventArgs e)
{
((Button)sender).Text = "Hellooooo";
}
}
Now add a page in your project & copy the below codes under page_load event:
protected void Page_Load(object sender, EventArgs e)
{
DataTable dt = new DataTable();
dt.Columns.Add("FirstName");
dt.Columns.Add("LastName");
dt.Columns.Add("Age", typeof(System.Int32));
DataRow oItem = dt.NewRow();
oItem[0] = "Shawpnendu";
oItem[1] = "Bikash";
oItem[2] = 32;
dt.Rows.Add(oItem);
oItem = dt.NewRow();
oItem[0] = "Bimalendu";
oItem[1] = "Bikash";
oItem[2] = 27;
dt.Rows.Add(oItem);
GridView gv = new GridView();
gv.AutoGenerateColumns = false;
BoundField nameColumn = new BoundField();
nameColumn.DataField = "FirstName";
nameColumn.HeaderText = "First Name";
gv.Columns.Add(nameColumn);
nameColumn = new BoundField();
nameColumn.DataField = "LastName";
nameColumn.HeaderText = "Last Name";
gv.Columns.Add(nameColumn);
nameColumn = new BoundField();
nameColumn.DataField = "Age";
nameColumn.HeaderText = "Age";
gv.Columns.Add(nameColumn);
// Here is template column portion
TemplateField TmpCol = new TemplateField();
TmpCol.HeaderText = "Click Me";
gv.Columns.Add(TmpCol);
TmpCol.ItemTemplate = new TemplateHandler();
gv.DataSource = dt;
gv.DataBind();
Form.Controls.Add(gv);
}
Now run the page & click on the button that i have added in a template column will say you "Helloooo".
Here
I showed an example how one can create runtime gridview with bound
& template column. Experiment it & hope you will achieve your
client target.
No comments:
Post a Comment