早!
我有一个带有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:我不使用母版页,因为我更喜欢在页面之间使用松散耦合,以方便它们之间的多样化。
答案 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>