日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

Response 输出文件流过程中的等待效果

發布時間:2025/5/22 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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 输出文件流过程中的等待效果的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。