在页面加载数据 asp.net 时使用母版页显示加载消息



我花了几个小时在谷歌上搜索和搜索过去的问题,但很难得到这些答案(无论是我无法正确将其放入我的解决方案中,还是它不适合我,因为他们没有母版页)。

我的问题是,我有几个 asp.net 页面可能需要一段时间才能加载(有时是 5 秒+),因为从 Page_Load 方法的数据库中请求了大量数据。为了防止用户认为页面已崩溃并刷新页面或执行其他操作,我想在加载时放置一条加载消息,隐藏页面上的其他所有内容(菜单除外)。

我正在使用带有母版页和 C# 编码的 ASP.Net 4.0。

我最成功的是在我的母版页上使用 UpdatePanel,其中内容模板覆盖了内容占位符,但是我知道这不是最好的方法,无论如何它只显示一次,即用户登录,出现加载消息,一旦所有数据加载到主页(仪表板.aspx)上,加载消息就会消失, 这就是我想要的。但是,如果用户离开该页面,然后单击主页,则加载消息将永远不会再次出现,只是需要一段时间才能加载。对于需要明显时间加载的任何其他页面,它也不会显示。

下面是主人的身体.aspx

<body>
<form runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server">
</asp:ScriptManager>
<div class="page">
    <div class="header">
        <div class="title">
            <h1>
                Header
            </h1>
        </div>
        <div class="loginDisplay">
            <asp:LoginView ID="HeadLoginView" runat="server" EnableViewState="false">
                <AnonymousTemplate>
                    [ <a href="~/Account/Login.aspx" id="HeadLoginStatus" runat="server">Log In</a>
                    ]
                </AnonymousTemplate>
                <LoggedInTemplate>
                    Welcome <span class="bold">
                        <asp:LoginName ID="HeadLoginName" runat="server" />
                    </span>! [
                    <asp:LoginStatus ID="HeadLoginStatus" runat="server" LogoutAction="Redirect" LogoutText="Log Out"
                        LogoutPageUrl="~/Default.aspx" />
                    ]
                </LoggedInTemplate>
            </asp:LoginView>
        </div>
        <div class="clear hideSkiplink">
            <asp:Menu ID="NavigationMenu" runat="server" CssClass="menu" EnableViewState="false"
                IncludeStyleBlock="false" Orientation="Horizontal" OnMenuItemClick="NavigationMenu_MenuItemClick">
                <Items>
                    <asp:MenuItem Text="Home" />
                    <asp:MenuItem Text="About" />
                </Items>
            </asp:Menu>
        </div>
    </div>
    <div class="main">
         <asp:UpdatePanel ID="UpdatePanel1" runat="server">
            <ContentTemplate>
                <asp:ContentPlaceHolder ID="MainContent" runat="server" />
                <asp:UpdateProgress ID="UpdateProgress1" runat="server">
                    <ProgressTemplate>
                        <asp:Panel ID="Panel1" runat="server" HorizontalAlign="Center">
                            <asp:Image ID="Image1" runat="server" ImageUrl="~/Images/loader.gif" />
                        </asp:Panel>
                    </ProgressTemplate>
                </asp:UpdateProgress>
            </ContentTemplate>
        </asp:UpdatePanel>

         <asp:UpdatePanelAnimationExtender ID="UpdatePanel1_UpdatePanelAnimationExtender" 
             runat="server" Enabled="True" TargetControlID="UpdatePanel1">
         </asp:UpdatePanelAnimationExtender>

    </div>
    <div class="clear">
    </div>
</div>
<div class="footer">
</div>
</form>

下面是仪表板的页面.aspx(加载时间较长的页面)

<asp:Panel ID="PanelWelcome" runat="server">
    <h1>
        Welcome
        <asp:Label ID="LabelUserName" runat="server" Text="[User Name]" />&nbsp;to your
        personal Dashboard.</h1>
    <table width="100%" cellpadding="5px">
        <tr>
            <td style="width: 70%" valign="top">
                <asp:Panel ID="Panel2" runat="server">
                    <p>
                        &nbsp;</p>
                    <h4>
                        Up and Coming </h4>
                    <br />
                    <asp:GridView ID="GridViewItin" runat="server" Width="100%" HorizontalAlign="Left"
                        OnRowDataBound="GridViewItin_RowDataBound">
                    </asp:GridView>
                </asp:Panel>
            </td>
            <td style="width: 30%">
                <asp:Panel ID="PanelProfile" runat="server">
                    <asp:ImageButton ID="ImageButtonProfile" runat="server" ImageUrl="~/Images/BlankProfile.jpg"
                        Width="150px" /><br />
                    <h4>
                        Name:</h4>
                    <asp:Label ID="LabelPARname" runat="server" Text="[Person Name]"></asp:Label>
                    <h4>
                        Company:</h4>
                    <asp:Label ID="LabelBARname" runat="server" Text="[Company Name]"></asp:Label>
                    <h4>
                        Date of Birth:</h4>
                    <asp:Label ID="LabelPARdob" runat="server" Text="[DOB]"></asp:Label><br />
                    <asp:LinkButton ID="LinkButtonProfilePage" runat="server" OnClick="LinkButtonProfilePage_Click">More details...</asp:LinkButton>
                </asp:Panel>
            </td>
        </tr>
    </table>
</asp:Panel>

你能告诉我最好的方法以及我哪里出错了吗?另外,当更新进度模板显示时,我如何隐藏内容模板会很棒?

谢谢。

好的,所以我弄清楚我做错了什么,我想我会发布我所做的,希望能帮助可能最终遇到相同问题的其他人......

基本上我没有从逻辑上考虑过。更新面板之外有一些控件,例如导航菜单,它永远不会触发更新进度,因为它们与面板无关!我不得不向更新面板添加触发器来处理面板外发生的所有事情。

因此,在我的母版页中,我有以下代码

<asp:UpdatePanel ID="UpdatePanel1" runat="server">
        <ContentTemplate>
            <asp:ContentPlaceHolder ID="MainContent" runat="server" />
        </ContentTemplate>
        <Triggers>
            <asp:AsyncPostBackTrigger ControlID="NavigationMenu" />
        </Triggers>
    </asp:UpdatePanel>
    <asp:UpdateProgress ID="progress" runat="server" DynamicLayout="true" DisplayAfter="0">
            <ProgressTemplate>
                <div id="overlay">
                    <div id="modalprogress">
                        <div id="theprogress">
                            <asp:Image ID="loader" runat="server" ImageAlign="AbsMiddle" ImageUrl="~/images/loader.gif" />
                            Please wait...
                        </div>
                    </div>
                </div>
            </ProgressTemplate>
        </asp:UpdateProgress>  

     <asp:UpdatePanelAnimationExtender ID="UpdatePanel1_UpdatePanelAnimationExtender" 
         runat="server" Enabled="True" TargetControlID="UpdatePanel1">
     </asp:UpdatePanelAnimationExtender>

希望这对其他人有所帮助!

您可以使用 UpdateProgress 控件。您可以从Ajax扩展选项卡下的收费框中获取它。我正在向你描述一个场景:
假设我有一个更新面板名称 UpdatePnl1 ,因为我有一个按钮说 GO.当我们点击 go 时,它应该重定向到另一个页面。在此之前,它会让你期待,请稍候。

现在我的代码将是这样的

<asp:UpdatePanel ID="UpdatePnl1" runat="server">
<ContentTemplate>
<asp:Button ID="BtnGO" runat="server" Text="GO" onclick="BtnGO_Click"/>
</ContentTemplate>
</asp:Updatepanel>

按钮点击代码:

 protected void BtnGO_Click(object sender, EventArgs e)
    {
        Response.Redirect("Example.aspx");
    }

现在这里是您需要添加的更新进度的代码

<asp:UpdateProgress ID="UpdateProgress1" runat="server" AssociatedUpdatePanelID="UpdatePnl1" >
      <ProgressTemplate>
      <asp:Label ID="LblWaitMsg" runat="server" Text="Processing Request, Please Wait..."></asp:Label>           
       </ProgressTemplate>
 </asp:UpdateProgress>

注意:您的页面应包含脚本管理器。

相关内容

  • 没有找到相关文章

最新更新