媒介
我的项目中有一个需求:点击按钮天生可编辑的word文档定单概况的信息
我运用的前端框架是Vue.js、背景运用的是node.js
node.js天生和导出word文档我参考的是下面这两篇文章,写的挺好的(github上的那篇内里另有node.js天生word、excel、ppt的example,须要细致的能够看内里)
http://blog.csdn.net/liyanhui…
https://github.com/Ziv-Barber…
题目
node.js上面这两篇文章已讲的很不错了,然则我在完成的过程当中照样涌现了一个题目:我在后端能天生一个完全的word文档,然则在返回前端下载的时刻遇到了题目。一最先我一直都认为node.js背景方面的代码致使的,毕竟我是第一次写嘛^_^,然则在不停的测试中我发明:
1、点击按钮用vue内里的axios要求localhost:8081/order/getDoc没有直接天生word文档,把返回的数据console.log(res)出来检察,发明获得的数据是一堆的乱码的字符串
2、然则在浏览器地址栏中要求一样的后端接口,发明能天生一个全部的word文档!
题目泉源
有了眉目我就最先上网征采,我发明,ajax的接收范例只能是string字符串,不是流范例,所以没法完成文件下载。ajax体式格局要求的数据只能寄存在javascipt内存空间,能够经由过程javascript接见,然则没法保存到硬盘,由于javascript不能直接和硬盘交互,不然将是一个安全题目。
axios是第一个第三方的ajax库,所以同理。
处理要领
处理的要领我参考了一篇文章前端axios下载excel(二进制)https://www.cnblogs.com/xueji…
处理要领:利用了blob对象,Blob对象能够看作是寄存二进制数据的容器,它是一个二进制大对象,是一个能够存储二进制文件的容器。
methods:{
handleClick(row){
console.log(row);
var orderId = row.orderId + row.oid.toString();
console.log(orderId);
this.$ajax({
method:"get",
url:"http://localhost:8081/order/getDoc",
responseType:'blob'
}).then((res)=>{
//这里res.data是返回的blob对象
var blob = new Blob([res.data], {type: 'application/vnd.openxmlformats-officedocument.wordprocessingml.document;charset=utf-8'}); //application/vnd.openxmlformats-officedocument.wordprocessingml.document这里示意doc范例
var downloadElement = document.createElement('a');
var href = window.URL.createObjectURL(blob); //建立下载的链接
downloadElement.href = href;
downloadElement.download = orderId+'.docx'; //下载后文件名
document.body.appendChild(downloadElement);
downloadElement.click(); //点击下载
document.body.removeChild(downloadElement); //下载完成移除元素
window.URL.revokeObjectURL(href); //释放掉blob对象
})
}
}