在MVC中通过AJAX下载Excel文件
处理MVC中的大型表单时,可能需要生成一个Excel文件,其中包含表单特定子集的数据,而不会影响其余部分。AJAX通过允许您向服务器发出部分请求来为此提供解决方案。
无法直接下载Excel文件
不幸的是,您无法直接通过AJAX返回要下载的文件。相反,请探索使用AJAX将相关数据发布到服务器的替代方法。
服务器端文件生成和响应
在您的服务器上,您可以使用服务器端代码生成Excel文件。为此,请考虑使用EPPlus或NPOI之类的库。然后,您可以将已创建文件的路径或文件名作为返回值传递回您的AJAX调用。
重定向到文件下载
在客户端的JavaScript中,您可以使用window.location = '/Reports/Download?file=' returnValue
将JavaScript窗口位置设置为文件的URL,从而提示浏览器下载它。
无缝的用户体验
这种方法提供了无缝的用户体验,因为文件下载操作不会离开源页面。
AJAX调用示例
以下是实现此目的的AJAX调用的示例:
$.ajax({
type: 'POST',
url: '/Reports/ExportMyData',
data: '{ "dataprop1": "test", "dataprop2" : "test2" }',
contentType: 'application/json; charset=utf-8',
dataType: 'json',
success: function (returnValue) {
window.location = '/Reports/Download?file=' returnValue;
}
});
用于文件下载的控制器方法
下载操作的相应控制器方法可能如下所示:
[HttpGet]
public virtual ActionResult Download(string file)
{
string fullPath = Path.Combine(Server.MapPath("~/MyFiles"), file);
return File(fullPath, "application/vnd.ms-excel", file);
}
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3