日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

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

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