标签:
大家在导出EXCEL时一般最后都会用到下载保存,用Response来实现。比如,以下是一个用NPOI导出EXCEL的下载EXCEL的实现:
Response.Clear(); Response.ClearHeaders(); Response.ContentType = "application/octet-stream"; Response.AddHeader("Content-Disposition", "attachent;filename=" + HttpUtility.UrlDecode("文件名.xls")); Response.WriteFile(临时文件路径, true); Response.Flush(); Response.Close();
最近,遇到一个问题,当页面中用了<asp:UpdatePanel>控件,下载Excel的功能,保存提示框总是无法弹出。
经过分析,后发现是Response和<asp:UpdatePanel>不太对付。原因是在页面中使用<asp:UpdatePanel>,但是在<asp:UpdatePanel>范围内的按钮的事件,没有使用UpdatePanel规范的trigger方式。
那么就需要增加触发器来实现按钮事件,模型如下:
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Always"> <ContentTemplate> //页面内容 </ContentTemplate> <Triggers> <asp:PostBackTrigger ControlID="按钮ID" /> //或者<asp:AsyncPostBackTrigger ControlID="按钮ID" /> </Triggers> </asp:UpdatePanel>
当然了,触发器也有两种,PostBackTrigger——整个页面刷新,AsyncPostBackTrigger局部刷新,
在本文中,如果想要支持Response的使用,必须使用AsyncPostBackTrigger来实现。
ASP.NET-019:UpdatePanel中无法使用Response问题
标签:
原文地址:http://blog.csdn.net/yysyangyangyangshan/article/details/50828819