Programmatically Adding User Controls Inside An UpdatePanel

后端 未结 3 1187
佛祖请我去吃肉
佛祖请我去吃肉 2020-12-13 16:05

I\'m having trouble dynamically adding controls inside an update panel with partial postbacks. I\'ve read many articles on dynamic controls and I understand how to add and m

3条回答
  •  悲&欢浪女
    2020-12-13 16:34

    This is, I think, one of the common pitfalls for asp.net programmers but isn't actually that hard to get it right when you know what is going on (always remember your viewstate!).

    the following piece of code explains how things can be done. It's a simple page where a user can click on a menu which will trigger an action that will add a user control to the page inside the updatepanel.
    (This code is borrowed from here, and has lots more of information concerning this topic)

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="SampleMenu1.aspx.cs" Inherits="SampleMenuPage1" %>
    
    
    
        Sample Menu
    
    
        


    and

    using System;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    
    public partial class PlainSampleMenuPage : System.Web.UI.Page
    {
        private const string BASE_PATH = "~/DynamicControlLoading/";
    
        private string LastLoadedControl
        {
            get
            {
                return ViewState["LastLoaded"] as string;
            }
            set
            {
                ViewState["LastLoaded"] = value;
            }
        }
    
        private void LoadUserControl()
        {
            string controlPath = LastLoadedControl;
    
            if (!string.IsNullOrEmpty(controlPath))
            {
                PlaceHolder1.Controls.Clear();
                UserControl uc = (UserControl)LoadControl(controlPath);
                PlaceHolder1.Controls.Add(uc);
            }
        }
    
        protected void Page_Load(object sender, EventArgs e)
        {
            LoadUserControl();
        }
    
        protected void Menu1_MenuItemClick(object sender, MenuEventArgs e)
        {
            MenuItem menu = e.Item;
    
            string controlPath = string.Empty;
    
            switch (menu.Text)
            {
                case "Load Control2":
                    controlPath = BASE_PATH + "SampleControl2.ascx";
                    break;
                case "Load Control3":
                    controlPath = BASE_PATH + "SampleControl3.ascx";
                    break;
                default:
                    controlPath = BASE_PATH + "SampleControl1.ascx";
                    break;
            }
    
            LastLoadedControl = controlPath;
            LoadUserControl();
        }
    }
    

    for the code behind.

    That's basically it. You can clearly see that the viewstate is being kept with LastLoadedControl while the controls themselves are dynamically added to the page (inside the updatePanel (actually inside the placeHolder inside the updatePanel) when the user clicks on a menu item, which will send an asynchronous postback to the server.

    More information can also be found here:

    • http://aspnet.4guysfromrolla.com/articles/081402-1.aspx
    • http://aspnet.4guysfromrolla.com/articles/082102-1.aspx

    and of course on the website that holds the example code I used here.

提交回复
热议问题