Click here to Skip to main content
Click here to Skip to main content

Dynamically Created Controls in ASP.NET

By , 27 Aug 2004
 

Introduction

Adding controls to an ASP.NET WebForm at runtime is a simple task:

private void Page_Load(object sender, System.EventArgs e)
{
    Button newButton = new Button();
    newButton.Text = "New Button"; 
    newButton.ID = "newButton"; 
    newButton.Click += new System.EventHandler(this.newButton_Click); 

    WebUserControl1 newUserControl = 
           (WebUserControl1)LoadControl("WebUserControl1.ascx"); 
    newUserControl.ID = "newUserControl";
    this.PlaceHolder.Add(newUserControl); 
    this.PlaceHolder.Add(newButton);
}

Problem

Now, let's raise a bit little. What if we want to add a new control as a result of some user action (button click, for example)? We are moving the same code from Page_Load to Button_Click event and… here troubles begin. Our controls will show as expected, but only the first time. Any postback will reset the page to its original state. Dynamically created controls will be unable to fire any event. What is happening here? The answer is simple. Page class is stateless. It is destroyed after rendering. Page recreates child controls collection, based on tags in aspx file, then postback data can be handled and event handlers attached (in OnInit event). Controls we just created dynamically do not exist in aspx file; Page has no knowledge about them.

Solution

The solution is also simple. We have to recreate controls on load stage of page lifecycle. After it's done, each control can handle its postback data, retrieve saved viewstate, raise events etc.

Now, the code skeleton will look like this:

private void Page_Load(object sender, System.EventArgs e)
{
    RecreatePersistedControls();
}
private void Button_Click(object sender, System.EventArgs e)
{
    CreateControl("newControl");
    PersistControl("newControl");
}
private void RecreatePersistedControls()
{
    // Call CreateControl for each persisted control
}
private void CreateControl(string id)
{
    // Create controll with specified id, 
    // add it to controls collection, attach event handlers
}
private void PersistControl(string id)
{
    // Persist specified id (in session for example)
}

Download source files to see the fully functional sample.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Leon Langleyben
Web Developer
Israel Israel
Member
Leon works as Chief Architect at SRL Group. He leads architectural design and development of various enterprise level projects.
You can meet him on user groups, conferences and forums dedicated to Architecture, ASP.NET, Team System etc. or join him for the next white water rafting adventure

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
Hint: For improved responsiveness ensure Javascript is enabled and choose 'Normal' from the Layout dropdown and hit 'Update'.
You must Sign In to use this message board.
Search this forum  
    Spacing  Noise  Layout  Per page   
QuestionValidating and save Dynamically created server side controls data into databasememberankushbelorkar15 Feb '13 - 21:02 
QuestionAnother linkmembersandip_frm_NEPAL22 Jun '12 - 4:52 
Questiontotally dynamic controlsmembermathewtinu25 Apr '12 - 9:59 
Questionusing vb?memberJavaCookies19 Jan '12 - 19:24 
i can't translate this to vb. how can i do this? please help me. Thanks
AnswerExcellent!memberhungvm25 Mar '09 - 23:34 
Questionhow to add events to dynamically created and binding linksmemberMember 40714403 Mar '09 - 3:32 
AnswerRe: how to add events to dynamically created and binding linksmemberamit_jain_online15 Apr '12 - 22:15 
QuestionHow do you find the path to the control later?membermicha.gluskin25 Nov '08 - 4:49 
GeneralAfter the Post back, control is disappeared.memberantonyvijayan3 Jun '08 - 1:38 
GeneralRe: After the Post back, control is disappeared.memberantonyvijayan14 Jul '08 - 23:25 
QuestionProb with dynamic menulist event at runtimememberHarry Sun7 May '08 - 3:34 
QuestionImageButton helpmemberjdanastasi5 Apr '08 - 22:15 
GeneralBig Thankxmemberjoeizzy24 Jun '07 - 16:43 
QuestionAdding controls in flow layoutmembermitdej10 May '07 - 20:56 
QuestionHow do I add radio Buttons in a table row and control them programaticallymembercyprosoft23 Feb '07 - 7:28 
Generalprob with fire eventhandeler for Dynamically Created Controls in ASP.NETmemberchiluka satish16 Feb '07 - 12:14 
GeneralTHANK YOU THANK YOU THANK YOU THANK YOU THANK YOUmemberbmatz18 Oct '06 - 6:38 
Questionhow to add new controls and fire its event at runtimememberdearvivek25 Sep '06 - 20:32 
GeneralWorks for LinkButton but not ImageButtonmemberAndy R Hore27 Feb '06 - 4:39 
GeneralRe: Works for LinkButton but not ImageButtonmembermbsum3 Sep '06 - 21:09 
Generaldynamic controls and the control treesussAnonymous17 Jul '05 - 14:37 
GeneralDynamically adding a user control based on an event from another controlmembersempko13 Jul '05 - 19:46 
GeneralRe: Dynamically adding a user control based on an event from another controlsussAnonymous28 Aug '05 - 14:00 
GeneralPage Load Occurs first on Button Click EventsussAnonymous11 May '05 - 20:08 
GeneralRe: Page Load Occurs first on Button Click Eventmemberhetauda18 Aug '06 - 7:00 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Permalink | Advertise | Privacy | Mobile
Web03 | 2.6.130523.1 | Last Updated 28 Aug 2004
Article Copyright 2004 by Leon Langleyben
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid