React纯前端生成word文档(支持多图片导出)

  • 前言
    • 准备工作
    • 代码实现
    • 结语
    • 参考

前言

作为一个入职不就的前端小白来说,前段时间的项目中老大提了一个在我看来十分无理的需求,对!无理。他要求我用纯前端实现一个word文档导出功能,并且附模板。我当即就否决了他(这压根就触及到我知识盲区了…),随后他在长达两个半小时对我的思(hu)想(shuo)教(ba)育(dao)中。我当然是还是选择妥协了(毕竟自己老大我只能惯着啊…)。

准备工作

整个功能用到的相关技术还是比较多的,毕竟涉及到文件操作不是自己手撸封装的,自然得装不少轮子,其中最重要的是docxtemplater(重要归重要,这玩意儿得文档写的就是个坑)毕竟是个付费版,docxtemplater-image-module-free这个是个开源版本,他俩文档一样,但是少一个都不行。后来我用我仅有的两根脑神经理解了一下,后边这个是前边那个开源的一个图片导出的功能模块(毕竟前边那个是付费版…):

//-- 安装 docxtemplater
npm install docxtemplater pizzip  --save
//-- 安装 jszip-utils
npm install jszip-utils --save
//-- 安装 jszip
npm install jszip --save
//-- 安装 FileSaver
npm install file-saver --save
//安装 docxtemplater-image-module-free
npm install --save docxtemplater-image-module-free

代码实现

装好插件以后按照惯例开头引入组件页面,需要注意docxtemplater-image-module-free用Import引入可能会报错,需要换成require方式:

import docxtemplater from 'docxtemplater'
import PizZip from 'pizzip'
import JSZipUtils from 'jszip-utils'
import { saveAs } from 'file-saver'
import ImageModule from 'docxtemplater-image-module-free' //这句是导出图片用的
/*
上边这行代码不好使的情况下需要用var ImageModule = require('docxtemplater-image-module-free')
*/

为了方便理解,生成word文档和生成图片分开写,首先写一个纯文本的word导出。写一个函数以便调用。

/*********base64DataURLToArrayBuffer函数代码块--导出图片函数编写位置********
*/
function exportWord() {// 设置模板变量的值,这个就是模板里所插入的内容数据,根据需要写成动态就好了。var wordData = {textcontents:'123456789',//images: DataUrl //图片导出功能};// 读取并获得模板文件的二进制内容,是docxtemplater提供的固定写法JSZipUtils.getBinaryContent("/exportTemplate.docx", function (error, content) {// exportTemplate.docx是模板,React写在public里。我们在导出的时候,会根据此模板来导出对应的数据//图片导出功能/*var opts = {}opts.centered = false; //Set to true to always center imagesopts.fileType = "docx"; //Or pptxopts.getImage = function (chartId) {return base64DataURLToArrayBuffer(chartId);}//Pass the function that return image sizeopts.getSize = function () {return [450, 450];}var imageModule = new ImageModule(opts);*/// 抛出异常if (error) {throw error;}// 创建一个PizZip实例,内容为模板的内容let zip = new PizZip(content);// 创建并加载docxtemplater实例对象let doc = new docxtemplater()//.attachModule(imageModule) //图片导出功能.loadZip(zip).compile();// 生成一个代表docxtemplater对象的zip文件(不是一个真实的文件,而是在内存中的表示)doc.resolveData(wordData).then(function () {console.log('ready');doc.render();var out = doc.getZip().generate({type: "blob",mimeType: "application/vnd.openxmlformats-officedocument.wordprocessingml.document",});// 将目标文件对象保存为目标类型的文件,并命名(起一个自己需要的名字就好了)saveAs(out, "导出文件名.docx");})});}

然后再随便撸个div简单写个按钮调用函数:

 <div className="App"><button type="info" onClick={exportWord} >导出word文档</button></div>

到这里需要写一下word模板(光有代码没有容器是导不出来文件的/手动微笑),直接在{}中写入模板变量,导出后会自动插入,文字大小,格式可以在word里设置:

导出后效果:

能成功导出文字模板这事儿就算成了,写下来就考虑怎么把图片搞进来(其实单图导出和多图的导出差不多,只要弄明白数据格式就可以。)
以下是两张base64的图片地址,图片的话需要处理成base64格式才能用,不然导出后图片可能会不显示:

const DataUrl = [{src: ''},{src: ''}
]

有了base64的图片地址以后,需要调用docxtemplater提供的base64DataURLToArrayBuffer方法把地址处理成ArrayBuffer才能正常导出图片,否自会出现报错。(函数写的位置在之前代码中注释出来了

  function base64DataURLToArrayBuffer(dataURL) {console.log(dataURL);const base64Regex = /^data:image\/(png|jpg|svg|jpeg|svg\+xml);base64,/;if (!base64Regex.test(dataURL)) {return false;}const stringBase64 = dataURL.replace(base64Regex, "");let binaryString;if (typeof window !== "undefined") {binaryString = window.atob(stringBase64);} else {binaryString = new Buffer(stringBase64, "base64").toString("binary");}const len = binaryString.length;const bytes = new Uint8Array(len);for (let i = 0; i < len; i++) {const ascii = binaryString.charCodeAt(i);bytes[i] = ascii;}return bytes.buffer;}

做完这些以后,把之前纯文本导出的代码中带*//图片导出功能*的注释取消注释功能就实现了,最后记得把word模板做如下修改(有了代码还得有容器才能导出word呢):

结语

回头写这篇博客的时候,才发现这个功能实现起来是真的简单…

参考

https://blog.csdn.net/meimeilive/article/details/103150412
https://blog.csdn.net/weixin_43753330/article/details/103461870
https://docxtemplater.readthedocs.io/en/latest/index.html

React纯前端生成word文档(支持多图片导出)相关推荐

  1. Java使用FreeMarker自动生成Word文档(带图片和表单)

    Java使用FreeMarker自动生成Word文档(带图片和表单) 1 背景 2 目标效果 3 创建Word模板 3.1 创建模板文档 3.2 转换模板文档 3.3 处理模板文档中的占位符 3.4 ...

  2. 用Aspose.Words for .NET动态生成word文档中的图片或水印

    1.概述 在项目中生成word文档,这个功能很普遍的,一般生成都是纯文字或是列表的比较多,便于客户打印,而要把图片也生成到word文档中的需求有些客户也是需要的,例如产品图片.这次我们介绍的是如何利用 ...

  3. freemarker+Jfreechart生成Word文档(含图片)

    这几天再弄一个报表,要统计一些信息最终的部分展示结果如下: 基本工具freemarker,jfreechart 工程的部分结构如下 与生成Word有关的类主要有FreemarkerConfigurat ...

  4. poi生成word文档,插入图片,echar报表生成到word,word表格

    poi生成word文档,word表格,将echar报表生成到word 项目中用到生成word报表,报表中有表格的合并 .页眉.表格中会有报表图片.然后查找了网上的资料,利用echar生成柱状图,然后已 ...

  5. Javascript 前端生成Word文档

    最近做项目遇到要在Web上生成Word文件的需求.一般方案是用报表系统或者在后台生成.由于报表系统中生成的页面再转换成Word难以排版,这里就用前端生成的办法作为临时解决方案.直接上代码了,提供文字排 ...

  6. java 生成word_Java Web 生成Word文档(freemarker方式)

    首先在pom文件中加入下面这个依赖(不是Maven项目的话,把jar包导入项目即可) org.freemarker freemarker 2.3.23 1.创建带有格式的word文档,将该需要动态展示 ...

  7. Android 使用模板生成Word文档,支持手机直接查看word

    最近在项目工作中,碰到一个很棘手的需求,说是要在手机端根据模板生成word文档,而且不借助第三方的软件可以查看word文档,一开始听这个需求差不多蒙了,这要怎么做,为什么不把生成word文档这个工作放 ...

  8. Aspose.Words简单生成word文档

    Aspose.Words简单生成word文档 Aspose.Words.Document doc = new Aspose.Words.Document(); Aspose.Words.Documen ...

  9. 根据标准word模板生成word文档类库(开源)

    前言   最近因项目需要要自定义标准word模板,并以编码方式操作word模板.填充数据和生成word文档,于是自己写了条小"内裤"来实现这个功能.该"内裤"只 ...

  10. Java通过freemarker生成word文档

    文档生成目录 摘要 项目预期效果 使用freemaker生成word文档并下载 一:导入所需要的maven依赖 二:根据word文档生成我们需要的ftl模板文件 三:将word需要的数据存入一个map ...

最新文章

  1. php实现无限分类超牛逼,PHP超牛逼无限极分类生成树方法_php技巧
  2. 2017年7月十三日正式开始记录
  3. mac 使用svn记录
  4. excel 粘贴到web_最新技术让excel秒变web数据库
  5. c#读取Sybase中文乱码的解决办法
  6. linux win32disk,windows使用Win32DiskImager安装树莓派系统
  7. nyoj1306海拔
  8. spring连数据库的配置文件(applicationContext.xml)
  9. Flutter GetX 状态管理 使用入门 程序计数器 (二)
  10. 华扬联众携手搜狗,助雅诗兰黛跃居女神节“C位”
  11. curl 没有到主机的路由_安装RaspAP将树莓派变身为无线路由器
  12. phpstrom查看代码总行数_程序员实用工具,推荐一款代码统计神器GitStats
  13. SQLServer------Sql Server性能优化辅助指标SET STATISTICS TIME ON和SET STATISTICS IO ON
  14. Express高效查询纯真IP库插件lib-qqwry
  15. 未来物联网的一些问题
  16. n个单词输入次数 c语言,C语言问题,从键盘输入n个英语单词.输入格式为n,w1,w2,w3…wn,其中n表示随后输入的英语...
  17. github上很好的iOS资源集锦
  18. 流式计算利器-Storm
  19. 如何用Python+统计学,进行数据分析
  20. openCV中基于HSV的颜色判断(红色为例)

热门文章

  1. 数据时代的我们,应该拥有的大数据思维
  2. 基于Vue的移动端图片裁剪组件 vue-clip(完美兼容ios与安卓)
  3. eventFilter能进入dragEnter但没有event::drog
  4. 信息系统安全等级保护 备案表
  5. 如何查找计算机主机地址,ip地址查询 怎么查询电脑IP地址?
  6. [转]NHibernate中DateTime,int,bool空值的处理方法
  7. ArcMap进行标记符号制作
  8. 基于PTPX的功耗分析
  9. failed to locate @import file common/stylus/variable.styl
  10. C语言 取绝对值函数abs()使用及注意事项