vue导出excel文件流中文乱码问题及解决
更新时间:2022年06月02日 11:30:21 作者:Thekingyu
这篇文章主要介绍了vue导出excel文件流中文乱码问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
导出excel文件流中文乱码
解决此方法很多网上的差不多都可以。一下提供简单的方法
loads(){ let data={ userWord:this.dataList.userWord, examId:this.$route.query.id, exportType:this.active, } api.exportUserResult(data).then((res) => { const blob = new Blob([res.data]); const fileName = '考试成绩.xls'; const linkNode = document.createElement('a'); linkNode.download = fileName; //a标签的download属性规定下载文件的名称 linkNode.style.display = 'none'; linkNode.href = URL.createObjectURL(blob); //生成一个Blob URL document.body.appendChild(linkNode); linkNode.click(); //模拟在按钮上的一次鼠标单击 URL.revokeObjectURL(linkNode.href); // 释放URL 对象 document.body.removeChild(linkNode); }); },
注意:
填写
另住拦截器,因为判断result,没在正确里返回,所以我直接返回
导出excel乱码(锟斤拷唷?锟?;锟斤拷)
我这个是 post请求乱码了 ,如果是get,就直接window.open(url,'_blank')就可以了
1.“锟斤拷唷?锟?;锟斤拷”这种乱码信息导致的原因是:整个数据流的字符集 GBK=>UTF-8=>GBK导致的。
2. 前端代码:
axios({ method: "post", url: url, data: params, headers: { // ... 接口需要的请求头 }, responseType: "blob" }).then(response => { const blob = new Blob([res.data],{type: 'application/vnd.ms-excel'}); const fileName = res.headers["content-disposition"].split("=")[1]; //接口响应头定义的文件名 downloadFile(blob, fileName); });
//import { Message } from "element-ui"; /** * 文件下载, 对于下载链接可直接用 window.open(url, "_blank"); * @param {*} data 二进制数据或base64编码 Blob、String * @param {*} fileName 下载的文件命名,可带扩展名,跨域下无效 */ export function downloadFile(data, fileName) { let url = ""; let isBlob = false; const errMsg = "下载出错,文件数据无法识别!"; if (data instanceof Blob) { isBlob = true; url = window.URL.createObjectURL(data); } else if (typeof data == "string") { // base64编码 url = data; } else { Message.error(errMsg); return; } if ("download" in document.createElement("a")) { // 非IE下载 const tmpLink = document.createElement("a"); tmpLink.download = fileName || ""; tmpLink.style.display = "none"; tmpLink.href = url; document.body.appendChild(tmpLink); tmpLink.click(); window.URL.revokeObjectURL(tmpLink.href); // 释放URL 对象 document.body.removeChild(tmpLink); } else { // IE10+下载 if (isBlob) { window.navigator.msSaveBlob(data, fileName); } else { //Message.error(errMsg); console.log(errMsg); return; } } }
3. 感觉完美 但是结果下载下来的如一开始截图的乱码,其实代码没有问题,问题在于前端项目启用了mock.js,把所有 import 或 require @/mock 的地方注释调就可以了
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
最新评论