输入型页面保存时遮罩效果避免再次提交的方法

2 篇文章 0 订阅

其实本人的目的是想试验一个这样的功能,前台的按钮在后台事件中能给其他服务器控件赋值,特别是GridView绑定数据这种,但是由于数据量多,这个过程会比较慢,又想在前台加一个等待的遮罩提示,直到数据完全绑定到GridView上,遮罩层才消失。这就必须用Ajax。

刚发现了一种不需要Ajax的方法,但是刷新了整个页面,悲剧大哭若按钮事件执行完后,就跳转去其他页面,就不用介意是否刷新本页面了,最好是输入型页面,不适合数据查询类页面。先见代码,

页面代码:

  <asp:Label ID="lblName" runat="server">abc</asp:Label>
 <asp:Button ID="btnNone" runat="server" Text="None"  
OnClientClick="javascript: bsl_showLoadingDialog('请稍等');" 
            οnclick="btnNone_Click" />


JS代码:
 <script language="javascript" type="text/javascript" src="JScripts/jquery-1.8.3.js"></script>
    <script language="javascript" type="text/javascript" src="JScripts/jquery-ui-1.9.2.custom.min.js"></script>
    <link type="text/css" rel="Stylesheet" href="Css/jquery-ui-1.9.2.custom.min.css" />
    <script language="javascript" type="text/javascript">
        var loadingDialog = $('<div id="dialog" title="" width="100%"><p class="center"><img src="Images/loading.gif"/></p><br/><p class="center">Please wait for a little while.</p></div>');
        function bsl_showLoadingDialog(title) {   //此处是一个遮罩效果
            loadingDialog.dialog({
                modal: true,
                title: title,
                width: 400,
                height: 300,
                closeOnEscape: false,
                resizable: false
            });
            loadingDialog.parent().find('.ui-dialog-titlebar-close').hide();
        }
    </script>

C#后台代码:

  protected void btnNone_Click(object sender, EventArgs e)
        {
            Thread.Sleep(3000);    //此处睡眠3秒,模拟等待时间
            lblName.Text = DateTime.Now.ToString();
        }


原理分析:按钮的客户端Click事件添加了一个遮罩层,服务端的Click事件执行完后,由于Asp.net页面会重新呈现Render,因此就将遮罩给去掉了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值