在Ajax UpdateProgress中显示Jquery EasyUI函数

时间:2013-09-08 14:42:44

标签: javascript jquery asp.net ajax

早!

我有一个带有UpdateProgress的asp.net UpdatePanel,调用UserControl,在页面回发期间触发动画。在这种情况下,完美的工作,但我正试图对这个动画做一点改变,放置一个Easyui进度弹出窗口。

这是EasyUI进度弹出演示的URL:http://www.jeasyui.com/demo/main/index.php?plugin=Messager&theme=default&dir=ltr&pitem=#

这是我的ASPX代码:

<asp:UpdateProgress ID="UpdateProgress1" runat="server" AssociatedUpdatePanelID="UpdatePanel1">
    <ProgressTemplate>
        <uc1:Loading runat="server" ID="Loading" />
    </ProgressTemplate>
</asp:UpdateProgress>

和UserControl页面:

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="Loading.ascx.cs" Inherits="Test.UserControl.Loading" %>

<link href="css/loading.css" rel="stylesheet" type="text/css" />

<div class="LoadingContainerBackground">
<div class="LoadingGreyBackground">
</div>
<div class="LoadingTableHolder">
    <table style="text-align: center; width: 100%; border-spacing: 0; border-collapse: collapse;">
        <tr>
            <td colspan="3" style="height: 200px"></td>
        </tr>
        <tr>
            <td style="width: 38%"></td>
            <td style="width: 20%; height: 175px; text-align: center; vertical-align: middle">
                <asp:Image ID="update" runat="server" ImageUrl="img/loading.gif" />
            </td>
            <td style="width: 40%"></td>
        </tr>
    </table>
</div>
</div>

在这个实际的表单上,完美地工作,但我想在同一个UserControl上放置它以避免冗余:

function progress() {
    var win = $.messager.progress({
        title: 'Please waiting',
        msg: 'Loading data...'
    });
    setTimeout(function () {
        $.messager.progress('close');
    }, 5000)
}

并且此事件作为当前触发器触发。有人可以帮我这个吗?

PS:重要的是这个事件留在UserControl上,因为同样的事件将在项目中的几十个页面中使用。

PS2:我不使用母版页,因为我更喜欢在页面之间使用松散耦合,以方便它们之间的多样化。

1 个答案:

答案 0 :(得分:0)

解决!

我在回发的开始和结束时放置了一个javascript处理程序来控制动画的时间。

这是EX:

<script>
    Sys.Application.add_init(appl_init);

    function appl_init() {
        var pgRegMgr = Sys.WebForms.PageRequestManager.getInstance();
        pgRegMgr.add_beginRequest(BeginHandler);
        pgRegMgr.add_endRequest(EndHandler);
    }

    function BeginHandler() {
        var win = $.messager.progress({
            title: 'Please waiting',
            msg: 'Loading data...'
        });
        setTimeout(function () {
            $.messager.progress('close');
        }, 9999)
    }

    function EndHandler() {
        $.messager.progress('close');
    }
</script>