Vue-纯前端导出word文档
在项目中,我们可以借助后端返回文件流实现文件下载。如果前端有数据,也可以借助前端框架进行下载。本文将介绍如何在前端纯js实现word文档导出。
docxtemplater
贴一贴官网给的例子,我们将参考以下例子来实现。
jszip-utils
file-saver
安装
接下来就是安装以上工具
引入
在需要用到的组件中引入以上工具
创建模板文件
我们要先创建一个模板文件,事先定义好格式和内容。docxtemplater 之前介绍到是通过标签的形式来填充数据的,简单的数据我们可以使用{} + 变量名来实现简单的文本替换。
- 简单的文本替换
如果在模板中,定义
在设置数据时,定义
最终生成的文件,如下
有点像jsp中的变量解析。
- 循环输出
稍微复杂点的像表格,我们会传递一个数组。那这个表格标签实现起来挺简单的,例子如下:
模板文件,定义如下:
设置数据时,定义如下:
最终实现效果如下:
如果数组中的都是字符串,不是对象类型,比如数据结构如下
那么,模板文件中应该这样设置
最终的文件内容如下:
还有一些其它的复杂标签,比输支持条件判断,支持段落等等,笔者就不在这里一一赘述了。详情参考官网文档。笔者的要导出的比较简单,前端页面如下:
前端
模板如下,笔者放在了\static\model.docx路径下:
注意:
1.本文因为开发使用了前后端分离,前端使用VsCode,我放在了前端的public文件夹下,其他位置我没有成功。
2.每当修改了模板,并重新替换掉原先模板后,需要把文件先移动到其他路径,再移回来,目的是让vue路径更新,否则更新不过去。(会提示找不到该文件,是否是zip文件之类的错误。如果发现替换后就更新过去了,便不必这样操作)。
模板
使用
我们可以参照 docxtemplater 给出的例子, 来实现文件导出。
- 读取模板文件内容
- 装载到zip对象中
- 设置文件数据
- 生成文件
- 保存文件
代码如下:
最终下载的效果如下
image.png
注意
- docxtemplater 不支持jszip,会有报错,因此要使用PizZip
- 注意模板的路径要写正确,不然会报错找不到文件
总结
本文简单的介绍了如何在前端使用已有的工具来实现前端导出word文档,希望对有类似需求的童鞋们有所帮助。
参考文章: