UpdatePanel未显示动态添加的UserControl

时间:2014-06-05 12:46:45

标签: c# asp.net user-controls updatepanel

我有一个UpdatePanel,其中包含两个HiddenField元素,用于确定要转换为UserControl元素的PlaceHolder。在初始加载时,放入一个(这很好)。有两个按钮,根据单击哪个按钮,会出现PostBack并且应该在所选控件中进行交换。

单击按钮时,会出现PostBack,但在网络调用中,我看不到返回任何HTML,显然页面上没有任何呈现。我对ASP.NET了解不多,搜索结果还没有引出我的解决方案或适合我的方法。

更新小组

<!-- Update Panel -->
<asp:UpdatePanel ID="PendingApprovalList" UpdateMode="Conditional" runat="server">
    <ContentTemplate>
        <!-- Page Navigation Bar -->
        <div style="margin-top: 100px;">
            <!-- Secret Sauce -->
            <asp:HiddenField ID="hf_onChartsPage" runat="server" value="true" />
            <asp:HiddenField ID="hf_onTablesPage" runat="server" value="false" />

            <!-- Navigation Clickables -->
            <a ID="ChartsTab" class="googleAnalyticsNav" runat="server" onserverclick="ChartsClicked">Chart View</a>
            <a ID="TablesTab" class="googleAnalyticsNav" runat="server" onserverclick="TablesClicked">Table View</a>
        </div>

        <!-- Page Content PlaceHolder -->
        <asp:PlaceHolder ID="AnalyticsContent" runat="server"></asp:PlaceHolder>
    </ContentTemplate>
</asp:UpdatePanel>

主页代码背后

    public partial class LocalGoogleReports : System.Web.UI.UserControl {
    //Constants
    private const string CHARTS_PATH = @"~/userctrls/Admin/Dashboard/Local/AnalyticsCharts.ascx";
    private const string TABLES_PATH = @"~/userctrls/Admin/Dashboard/Local/AnalyticsTables.ascx";

    //Properties
    public int CENTER_NUM;
    public string CENTER_NAME;
    public bool GoToChartsPage {
        get {
            return bool.Parse(hf_onChartsPage.Value);
        }
        set {
            hf_onChartsPage.Value = value.ToString();
        }
    }
    public bool GoToTablesPage {
        get {
            return bool.Parse(hf_onTablesPage.Value);
        }
        set {
            hf_onTablesPage.Value = value.ToString();
        }
    }

    protected void Page_Load(object sender, EventArgs e) {
        if (!IsPostBack) {
            CENTER_NUM = SessionManager.Center.CenterNumber;
            CENTER_NAME = SessionManager.Center.CenterName.ToLower();
            AnalyticsContent.Controls.Clear();
            UserControl chartsControl = (UserControl)LoadControl(CHARTS_PATH);
            AnalyticsContent.Controls.Add(chartsControl);
        } else {
            if (GoToChartsPage) {
                LoadChartsUserControl();                    
            } else {
                LoadTablesUserControl();
            }
        }
    }

    protected void ChartsClicked(object sender, EventArgs e) {
        GoToChartsPage = true;
        GoToTablesPage = false;
    }
    protected void TablesClicked(object sender, EventArgs e) {
        GoToTablesPage = true;
        GoToChartsPage = false;
    }
    private void LoadChartsUserControl() {
        AnalyticsContent.Controls.Clear();
        UserControl chartsControl = (UserControl)LoadControl(CHARTS_PATH);
        AnalyticsContent.Controls.Add(chartsControl);
        ScriptManager.RegisterStartupScript(PendingApprovalList, GetType(), Page.UniqueID,
            "getAnalyticData();", true);
    }
    private void LoadTablesUserControl() {
        AnalyticsContent.Controls.Clear();
        UserControl tablesControl = (UserControl)LoadControl(TABLES_PATH);
        AnalyticsContent.Controls.Add(tablesControl);
    }
}

提前感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

尝试使用PendingApprovalList.UpdatePanel();加载图表或表格后