大家在导出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的使用,必须使用PostBackTrigger来实现。