使用Ajax生成的Excel文件并下载的实例
很久沒有寫文章啦,今天分享一個如何在ASP.NET MVC里使用Ajax下載生成文件的方法,以下只是個人心得: 大家都應該知道,在ASP.NET MVC里,如果通過Ajax調用后臺控制器時,可以返回一個JSON對象,但并不能直接返回文件(除非刷新頁面,那就不是Ajax啦),所以如果想用Ajax生成文件并下載的話,那只要將生成的文件先保存到服務器上,然後再將文件路徑通過JSON返回,之後才可以進行下載,當然由於是暫時性存放,所以當下載完后就需要馬上刪除相應的文件。 以下是做法以動態生成Excel為例(生成Excel的具體步驟我就省略了,這并不是此文章的重點): 1. 首先創建Action生成Excel文件 using (var exportData = new MemoryStream())
{ //如何生成Excel這里就不詳細說明啦,我這里對Excel的操作使用的是 NPOI Utility.WriteDataTableToExcel(dt,".xls",exportData);
} var errorMessage = "you can return the errors in here!"; //返回生成的文件名 2. 創建下載用的 Action 3. 由於要做到下載完后自動刪除文件,所以再創建一個 Action Filter 4. 最后在前臺添加 Ajax 調用的代碼: Please wait a moment...' });
$.ajax({
type: "POST",url: '@Url.Action("ExportExcel","YourController")',//調用相應的controller/action
contentType: "application/json; charset=utf-8",dataType: "json",}).done(function (data) {
//console.log(data.result);
$.unblockUI();
//接收返回的文件路徑,此文件這時已保存到服務器上了
if (data.fileName != "") {
//通過調用 window.location.href 直接跳轉到下載 action 進行文件下載操作
window.location.href = "@Url.RouteUrl(new { Controller = "YourController",Action = "Download"})/?file=" + data.fileName;
}
});
5. 完! 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |