首先这种模式适用于后端返回文件流的模式。
window.open() 打开新的链接,这个链接访问到文件地址之后,就开始下载。其实同理 用a链接下载也是可以的,a链接添加 download 属性,然后herf链接是要下载的文件
原文参考:https://blog.youkuaiyun.com/weixin_46074961/article/details/105677732 https://blog.youkuaiyun.com/qq_38555490/article/details/99697993
window.open发送的是什么请求?
window.open 默认get 请求,参数是跟在url后面的查询字符串形式。
如果想发送 post 请求(注意post请求是 发送文件)
原文参考:https://blog.youkuaiyun.com/menghuanzhiming/article/details/79298974
如果非要用axios获取文件(如 post 请求等)
this.shopMonthexport(this.getParams) .then(res => { const blob = new Blob([res.data], {type: "application/msword"});//这里是word文件,可根据需求自行更改 var contentDisposition = res.headers["content-disposition"]; var patt = new RegExp("filename=([^;]+\\.[^\\.;]+);*"); var result = patt.exec(contentDisposition); var fileName = result[1]; if ("download" in document.createElement("a")) { // 非IE下载 const elink = document.createElement("a"); var reg = /^["](.*)["]$/g; elink.download = decodeURI(fileName.replace(reg, "$1")); //下载后文件名 elink.style.display = "none"; elink.href = URL.createObjectURL(blob);//创建下载的链接 document.body.appendChild(elink); elink.click();//点击下载 URL.revokeObjectURL(elink.href); //释放掉blob对象 document.body.removeChild(elink);//下载完成移除元素 } else { // IE10+下载 navigator.msSaveBlob(blob, fileName); } }) .catch(e => { console.log(e); });
遇到的问题
1、
原因是路径有问题,可能是前端 路径没写对,也可能是后端相应路径还没有东西
2、
今天写出这个错的原因是 路径写错了