一,正常的点击按钮后,将其灰显,全部执行完毕再正常显示。

this.btnSave.Attributes.Add("onclick", "if (typeof(Page_ClientValidate)=='function' && Page_ClientValidate() == false)return false;document.all('" + btnSave.ClientID + "').disabled=true;if(typeof(__doPostBack)=='function')" + this.GetPostBackEventReference(btnSave) + ";");

btnSave为按钮ID。

二,

response 后刷新页面

先要求点按钮生成文件,同时按钮变灰,文件生成好直接打开该文件,按钮可用。

注意:internet安全设置,

下载——文件下载(启用)

文件下载——文件下载的自动提示(启用)

一、第一种方法,用iframe:

1,给按钮增加点击后变灰,页面刷新变可用属性。

打开文件代码如下:

 //写出文件
System.Text.Encoding encoding = System.Text.Encoding.GetEncoding("gb2312");
HttpResponse response = HttpContext.Current.Response;
response.HeaderEncoding = encoding;
response.Charset = encoding.HeaderName;
response.Clear();
response.ContentEncoding = encoding;
response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(pdfFile.Name));
response.AddHeader("Content-Length", pdfFile.Length.ToString());
response.ContentType = "application/pdf";
response.WriteFile(pdfFile.FullName);
HttpContext.Current.ApplicationInstance.CompleteRequest();

打开文件

要弹出文件,页面请求会立刻结束。所以这时你把按钮的任何控制都不会执行。

2,aspx页面:增加一个iframe

 <iframe id="ifrm_popMessage" src="" frameborder="0" scrolling="no" align="middle"
style="position: absolute; z-index: 100; display: none; border: 1px #62A3D2 solid;">
</iframe>

3,aspx页面:增加JS脚本:

////打开文件
function OpenPdfFile() {
document.getElementById('ifrm_popMessage').src = "OpenPdfFile.aspx?Rnd" + Math.random();
}

4,生成文件结束后增加如下代码:

 ScriptManager.RegisterStartupScript(this.Page, ClientScript.GetType(), "myscript", "<script>OpenPdfFile();</script>", false);

5,OpenPdfFile 页面代码:

/// <summary>
/// 用来生成PDF文件
/// </summary>
public partial class Admin_IEData_OpenPdfFile : System.Web.UI.Page
{
/// <summary>
/// 页面加载
/// </summary>
protected void Page_Load(object sender, EventArgs e)
{
DirectoryInfo di = new DirectoryInfo(Server.MapPath("~/File/"));
string strFileName = string.Format("{0}({1}){2}.pdf", di.FullName, SessionOperate.getLoginName(), "ddpdf");
FileInfo pdfFile = new System.IO.FileInfo(strFileName);
WriteOutFile(pdfFile);
} #region 写出文件
/// <summary>
/// 写出文件
/// </summary>
/// <param name="pdfFile">文件对象</param>
/// <returns>返回是否成功</returns>
protected bool WriteOutFile(FileInfo pdfFile)
{
//写出文件
System.Text.Encoding encoding = System.Text.Encoding.GetEncoding("gb2312");
HttpResponse response = HttpContext.Current.Response;
response.HeaderEncoding = encoding;
response.Charset = encoding.HeaderName;
response.Clear();
response.ContentEncoding = encoding;
response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(pdfFile.Name));
response.AddHeader("Content-Length", pdfFile.Length.ToString());
response.ContentType = "application/pdf";
response.WriteFile(pdfFile.FullName);
HttpContext.Current.ApplicationInstance.CompleteRequest();
return true;
}
#endregion
}

Iframe页面代码

二、这个方法比较好,再加一个隐藏按钮,点打印,把按钮变灰(加按钮属性实现),然后显示一个隐藏的字(正在打印……)结束后按钮恢复,字隐藏(加按钮属性实现)在打印后台代码里增加JS触发隐藏按钮onclik事件,隐藏按钮事件里写加载打印文件代码。

1、前台代码

<div style="text-align: center; margin-top: 5px;">
<cc1:JETButton ID="btnOk" runat="server" Text="打印" OnClick="btnOk_Click" />
<div id="exporting" style="display:none;"><br /><font color="#ff0000" size="4.5px">数据正在打印中,请稍等……</font></div>
</div>
<div style="display:none;">
<cc1:JETButton ID="btnDownload" runat="server" Text="下载" CssClass="hide" OnClick="btnDownload_Click" />
</div>

前台代码

2、 void Page_Load(object sender, EventArgs e)

this.btnOk.Attributes.Add("onclick", "if (typeof(Page_ClientValidate)=='function' && Page_ClientValidate() == false)return false;document.getElementById('" + btnOk.ClientID + "').disabled=true;document.getElementById('exporting').style.display='block';if(typeof(__doPostBack)=='function'){" + this.GetPostBackEventReference(btnOk) + ";}");

3、打印按钮onclick代码

 //生成打印
ClientScript.RegisterStartupScript(this.GetType(), "exported", "document.getElementById('" + btnOk.ClientID + "').disabled=false;document.getElementById('exporting').style.display='none';document.getElementById('" + btnDownload.ClientID + "').click();", true);

打印按钮onclick代码

4、点击下载按钮

/// <summary>
/// 点击下载按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnDownload_Click(object sender, EventArgs e)
{
//TODO:此处写下载打印合并的PDF
DirectoryInfo di = new DirectoryInfo(Server.MapPath("~/File/ExportTemplate/ExcelTmp/"));
string strFileName = string.Format("{0}({1}){2}.pdf", di.FullName, SessionOperate.getLoginName(), "pdf文件");
FileInfo pdfFile = new System.IO.FileInfo(strFileName);
WriteOutFile(pdfFile);
}

点击下载按钮

response 后刷新页面,点击按钮后,禁用该按钮的更多相关文章

  1. Ajax请求数据与删除数据后刷新页面

    1.ajax异步请求数据后填入模态框 请求数据的按钮(HTML) <a class="queryA" href="javascript:void(0)" ...

  2. Ajax异步调用http接口后刷新页面

    使用Ajax的目的就是提高页面响应速度,无需同步调用,无需整个页面刷新.这里直接在html中使用js来实现: 先获取XMLHttpRequest对象 var xmlHttp; //创建一个xmlHtt ...

  3. 用HTTP状态码实现提交表单后刷新页面不重复提交

    正常情况下,表单提交后如果用户刷新页面会重复提交表单,有些情况下我们不希望表单重复提交,利用HTTP协议中的307状态码重定向页面可以实现这个目的.实例如下: 表单页面代码: <form act ...

  4. <asp:TextBox><asp:LinkButton><input button>调用后台方法后刷新页面

    <asp:TextBox><asp:LinkButton>服务器控件,执行后台方法,会回调加载js,相当于页面重新加载,刷新页面 <input button>不能直 ...

  5. vue打包后刷新页面报错:Unexpected token <

    前言 今天遇到了一个很怪的问题,在vue-cli+webpack的项目中,刷新特定页面后页面会变空白,报错为index.html文件中Unexpected token <. 怪点一是开发环境没有 ...

  6. ajax删除数据后刷新页面

    代码如图: 理解: 发送请求后删除name 属性为 name 的data;用rem .remove删除: 删除后找到页面上app的数量:定义page = len/12+1; 找到当前页是哪一页,如果l ...

  7. HTML或者JSP页面--执行完某事件后刷新页面,重置表单,清空数据

    在提交表单或者执行某个事件之后,如果需要重置表单(即清空表单里的数据) 可以执行下面代码来完成 方式一: self.location.href="userController.do?goAd ...

  8. 使用element-ui的el-menu导航选中后刷新页面保持当前选中

    <el-menu :default-active=‘$route.path‘ :router=‘true‘ :unique-opened=‘true‘ :default-openeds=&quo ...

  9. LayUi前端框架删除数据缓存问题(解决删除后刷新页面内容又会显示问题)

    form.on('submit(mySearch)', function(data){ table.reload('userTable', {//就会读取后台数据,重新加载: page: { curr ...

随机推荐

  1. CSS skills: 1) Navigate item's animation

    <style> .nav { border-right:1px solid #268eb7; } .nav li{overflow:hidden;height:55px;border-le ...

  2. 使用markdown及highlight

    一.markdown 安装markdown2 pip install markdown2 应用markdown2 进入blog APP,创建templatetags文件夹,在文件夹内创建__init_ ...

  3. 虚拟机 VirtualBox 自制帮助文档

    初学 VirtualBox ,网络上教程很多,图片一张一张的费流量,讲得又比较散,于是花了一下午制作了此 CHM 帮助文档. 下载:(图片另存为--重命名为 RhinoC.rar --解压缩)

  4. BZOJ1975 [Sdoi2010]魔法猪学院

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...

  5. 【解决】应用程序无法正常启动(0xc000007b)。请单击“确定”关闭应用程序。

    换了SSD硬盘,装了Windows 7 SP1 x64的系统.用了一段时间,突然一天有些软件打不开了.弹出下面的提示 应用程序无法正常启动(0xc000007b).请单击“确定”关闭应用程序.第一时间 ...

  6. jquery jsonp实现跨域

    html代码: $("#testJsonp").click(function(){ $.ajax({ url: "http://www.test.cc/1.php&quo ...

  7. C#中参数传递【转】

    转自[Learning hard] 建议参考 『第十一回:参数之惑---传递的艺术(上)』 一.引言 对于一些初学者(包括工作几年的人在内)来说,有时候对于方法之间的参数传递的问题感觉比较困惑的,因为 ...

  8. 【转载】常用Maven插件介绍

    http://www.cnblogs.com/crazy-fox/archive/2012/02/09/2343722.html 我们都知道Maven本质上是一个插件框架,它的核心并不执行任何具体的构 ...

  9. android操作通讯录的联系人

    界面配置文件 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"     and ...

  10. Android 第三方授权(微信篇)

    0.申请开发者: https://open.weixin.qq.com/cgi-bin/frame?t=home/app_tmpl&lang=zh_CN 1.下载sdk包: https://o ...