0


docxtemplater避坑!!! 前端导出word怎么插入本地图片或base64 有完整示例

docxtemplater

库实现前端通过模板导出word,遇到需求,要插图片并转成

word

并导出,在图片转换这块遇到了问题,网上查示例大多都跑不通,自己琢磨半天,总算搞明白了。

附上清晰完整示例,供参考。

如有不懂,私我询问!

首先需要一个word文件作为模板test.docx

必须是

docx

文件!!!

{%}

代表图片

xgq

是变量

安装需要的包

npminstall docxtemplater
npminstall docxtemplater-image-module-free
npminstall pizzip
npminstall file-saver
npminstall html2canvas # 如需截图的话 安装
import Docxtemplater from'docxtemplater';import{ saveAs }from'file-saver';import PizZip from'pizzip';import ImageModule from'docxtemplater-image-module-free';import html2canvas from'html2canvas';import image from'./20240522152640.jpg';import docx from'./test.docx';

插入本地图片并转换

const imageData =awaitfetch(image);const imageArrayBuffer =await imageData.arrayBuffer();const imgDataDict: Record<string, ArrayBuffer>={
  xgq: imageArrayBuffer,};const docxData =awaitfetch(docx);const docxArrayBuffer =await docxData.arrayBuffer();const zip =newPizZip(docxArrayBuffer);const doc =newDocxtemplater(zip,{
  paragraphLoop:true,
  linebreaks:true,
  modules:[newImageModule({getImage:(value:string, key:string)=>{return imgDataDict[key];},getSize:(afterValue: ArrayBuffer, value:string, key:string)=>{return[400,400];},}),],});
doc.render({
  xgq:"xgq",// 这里得是字符串否则会报错});const blob = doc.getZip().generate({
  type:"blob",
  mimeType:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",});saveAs(blob,"download.docx");

插入base64图片并转换

const base64 ="";const imageArrayBuffer =base64DataURLToArrayBuffer(base64);const imgDataDict: Record<string, ArrayBuffer>={
  xgq: imageArrayBuffer,};const docxData =awaitfetch(docx);const docxArrayBuffer =await docxData.arrayBuffer();const zip =newPizZip(docxArrayBuffer);const doc =newDocxtemplater(zip,{
  paragraphLoop:true,
  linebreaks:true,
  modules:[newImageModule({getImage:(value:string, key:string)=>{return imgDataDict[key];},getSize:(afterValue: ArrayBuffer, value:string, key:string)=>{return[400,400];},}),],});
doc.render({
  xgq:"xgq",// 这里得是字符串否则会报错});const blob = doc.getZip().generate({
  type:"blob",
  mimeType:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",});saveAs(blob,"download.docx");
constbase64DataURLToArrayBuffer=(dataURL:string)=>{const base64Regex =/^data:image\/(png|jpg|jpeg|svg|svg\+xml);base64,/;if(!base64Regex.test(dataURL)){returnfalse;}const stringBase64 = dataURL.replace(base64Regex,"");let binaryString;if(typeof window !=="undefined"){
    binaryString = window.atob(stringBase64);}else{
    binaryString =newBuffer(stringBase64,"base64").toString("binary");}const len = binaryString.length;const bytes =newUint8Array(len);for(let i =0; i < len; i++){const ascii = binaryString.charCodeAt(i);
    bytes[i]= ascii;}return bytes.buffer;};

截图某个网页区域并插入转换

<div id="test" style={{ border:"1px solid red", width:300}}><div>截图</div><button type="button">666</button><br /><img src={image}/></div>;
const dom:any= document.getElementById("test");const canvas =awaithtml2canvas(dom,{
  useCORS:true,
  scale:5,});const imageDataURL = canvas.toDataURL("image/png");const response =awaitfetch(imageDataURL);const imageArrayBuffer =await response.arrayBuffer();const imgDataDict: Record<string, ArrayBuffer>={
  xgq: imageArrayBuffer,};const docxData =awaitfetch(docx);const docxArrayBuffer =await docxData.arrayBuffer();const zip =newPizZip(docxArrayBuffer);const doc =newDocxtemplater(zip,{
  paragraphLoop:true,
  linebreaks:true,
  modules:[newImageModule({getImage:(value:string, key:string)=>{return imgDataDict[key];},getSize:(afterValue: ArrayBuffer, value:string, key:string)=>{return[400,400];},}),],});
doc.render({
  xgq:"xgq",// 这里得是字符串否则会报错});const blob = doc.getZip().generate({
  type:"blob",
  mimeType:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",});saveAs(blob,"download.docx");
标签: 前端 word wps

本文转载自: https://blog.csdn.net/weixin_44488811/article/details/139157059
版权归原作者 xgq11 所有, 如有侵权,请联系我们删除。

“docxtemplater避坑!!! 前端导出word怎么插入本地图片或base64 有完整示例”的评论:

还没有评论