Содержимое повторителя не отображается после UpdatePanel PreRender

У меня есть повторитель, который я пытаюсь загрузить после загрузки страницы и наткнулся на событие PreRender. У меня все настроено, но содержимое повторителя не отображается - странно, что когда я проверяю html, код есть, просто не отображается в браузере.

    <asp:updatepanel id="panel1" runat="server" updatemode="Conditional" onprerender="upUpdatePanel_PreRender">
<contenttemplate>
<asp:repeater runat="server" id="mainContentRptr" onitemdatabound="bindDepts">
<headertemplate>
<div id="products-tabs-content" class="row tab-content">
    </headertemplate>
    <itemtemplate>
    <div class="tab-pane" id='<%# eval("dept_id") %>
        '> <asp:repeater runat="server" id="prodRepeater" onitemcommand="itemToCart">
        <headertemplate>
        .... </headertemplate>
        <itemtemplate>
        .... <asp:repeater runat="server" id="condRptr">
        <headertemplate>
        .... </headertemplate>
        <itemtemplate>
        .... </itemtemplate>
        <footertemplate></footertemplate>
        </asp:repeater>
        </itemtemplate>
        <footertemplate>
    </div>
    </footertemplate>
    </asp:repeater>
</div>
<!-- End .tab-pane -->
</itemtemplate>
<footertemplate>
</footertemplate>
</asp:repeater>
</contenttemplate>
</asp:updatepanel>

Как вы можете видеть несколько вложенных повторителей... у меня также есть элемент управления UpdateProgress.

<asp:UpdateProgress id="updateProgress" runat="server" AssociatedUpdatePanelID="panel1">
                                        <ProgressTemplate>
                                            <div style="position: relative; text-align: center; height: 100%; width: 100%; background-color: white; opacity: 0.7;margin:0 auto">
                                                <asp:Image ID="imgUpdateProgress" runat="server" ImageUrl="images/loader.GIF" AlternateText="Loading ..." ToolTip="Loading ..." style="padding: 10px; position: relative; top: 45%;margin: 0 auto" />
                                                <br/>
                                                <span style="font-size: 16pt;font-weight: bold">Bulding your menu</span>
                                                <br/>
                                                <span>Please wait</span>
                                            </div>
                                        </ProgressTemplate>
                                    </asp:UpdateProgress>

а затем следующее, чтобы вызвать отложенную загрузку

<script language="javascript" type="text/javascript">
                                        function pageLoad(sender, e) {
                                            if (!e.get_isPartialLoad()) {
                                                __doPostBack('<%= panel1.ClientID %>', 'aaaa');
                                            }
                                        }
                                    </script>

и серверная часть...

protected void upUpdatePanel_PreRender(object sender, EventArgs e)
        {
            if (Request["__EVENTTARGET"] == panel1.ClientID &&
                Request.Form["__EVENTARGUMENT"] == "aaaa")
            {
                populateRepeaters(); //This has databind for each repeater
            }
        }

Это работает без предварительного рендеринга, но скорость загрузки будет зависеть от данных и т. д., поэтому я хотел, чтобы он загружался после загрузки страницы.

Любая помощь будет оценена, ребята! :)


person JazziJeff    schedule 14.05.2014    source источник
comment
неважно - оказывается, это было что-то простое, у меня был репитер, сидящий вне панели обновлений, который контролировал видимость всего, что выше. он был заполнен в событии предварительной визуализации, но не отображался. Я переместил его внутрь панели, и теперь все работает :)   -  person JazziJeff    schedule 14.05.2014


Ответы (1)


ретранслятор сидел вне панели обновления, которая контролировала видимость всего, что было выше. он был заполнен в событии предварительной визуализации, но не отображался. Я переместил его внутрь панели, и теперь все работает.

person JazziJeff    schedule 15.05.2014