nodejs(officegen)+vue(axios)在客户端导出word文档

媒介

我的项目中有一个需求:点击按钮天生可编辑的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文档!

《nodejs(officegen)+vue(axios)在客户端导出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对象
            })
          }
     }

《nodejs(officegen)+vue(axios)在客户端导出word文档》

    原文作者:风子猪
    原文地址: https://segmentfault.com/a/1190000013729797
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞