Response 输出文件流过程中的等待效果
大家在寫程序過程中應該會遇到這樣的問題,就是我們需要導出excel,當我們往excel寫數據的時候,如果數據量較大的話,這個過程可能需要花些時間。
這個時候我們不能說讓用戶點完導出按鈕后就在那邊傻等,頁面上一點動靜沒有的話會讓不懂計算機的客戶很擔心的,也不知道到底自己點中了沒有,還是死機了。
所以在等待文件輸出的過程中最好能有一個等待的效果,比如一個遮罩層啊什么的,然后在?Response.WriteFile后把遮罩關閉。
????????????????前端我們需要調用一個遮罩的等待效果
??????? /*
這塊是一大堆往excel寫數據的過程,需要花時間
*/
??????????????? ? //這塊是輸出文件
Response.ClearContent();
??????????????????? Response.ClearHeaders();
??????????????????? Response.AddHeader("content-disposition", "attachment; filename=stafflist.xls");
??????????????????? Response.ContentType = "application/ms-excel";
??????????????????? Response.WriteFile(Server.MapPath("STemp/" +?rad + ".xls"));
???????????????????
??????????????????? Response.Flush();
??????????????????? Response.Close();
??????????????????? System.IO.File.Delete(Server.MapPath("STemp/" + rad+ ".xls"));
前面都還好辦,問題就是在文件流輸出后,怎么把遮罩層關掉。在?Response.Close();后面寫什么代碼都不管用了,哪怕像前臺注冊腳本,都沒有效果。
遮罩層一直在那,我不知道各位大神是怎么解決這個問題的,我在百度上也沒查到,我覺得應該也是這樣,我們都人為的把Response輸出內容改變了,
整個頁面應該是做不了其他什么動作了。
我自己想了個解決方案,就是把【往excel寫數據的過程】和【文件輸出過程分開】
?? $("#queding").click(function() {
這里調用等待效果的js
staffh.ashx這個文件里耗時的execl操作
? $.post("staffh.ashx", { json: myJsonData }, function(data) {
?????????????????????????? if (data == 'OK') {
????????????????????????????//這個時候關閉等待效果的js
?????????????????????????????? form1.submit();?//form1里面輸出文件流
?????????????????????????? }
?????????????????????? });
??? });
?
如果大家還有其他什么好的解決方案請指教。
?
轉載于:https://www.cnblogs.com/yexiang/p/3200530.html
總結
以上是生活随笔為你收集整理的Response 输出文件流过程中的等待效果的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: poj 2392 Space Eleva
- 下一篇: 鲜为人知的C++ IO fstream