当前位置:首页 » 《关于电脑》 » 正文

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

27 人参与  2024年10月07日 19:20  分类 : 《关于电脑》  评论

点击全文阅读


docxtemplater库实现前端通过模板导出word,遇到需求,要插图片并转成word并导出,在图片转换这块遇到了问题,网上查示例大多都跑不通,自己琢磨半天,总算搞明白了。

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

如有不懂,私我询问!

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

必须是docx文件!!!

{%} 代表图片 xgq是变量

安装需要的包

npm install docxtemplaternpm install docxtemplater-image-module-freenpm install pizzipnpm install file-savernpm install 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 = await fetch(image);const imageArrayBuffer = await imageData.arrayBuffer();const imgDataDict: Record<string, ArrayBuffer> = {  xgq: imageArrayBuffer,};const docxData = await fetch(docx);const docxArrayBuffer = await docxData.arrayBuffer();const zip = new PizZip(docxArrayBuffer);const doc = new Docxtemplater(zip, {  paragraphLoop: true,  linebreaks: true,  modules: [    new ImageModule({      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 = await fetch(docx);const docxArrayBuffer = await docxData.arrayBuffer();const zip = new PizZip(docxArrayBuffer);const doc = new Docxtemplater(zip, {  paragraphLoop: true,  linebreaks: true,  modules: [    new ImageModule({      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");
const base64DataURLToArrayBuffer = (dataURL: string) => {  const base64Regex = /^data:image\/(png|jpg|jpeg|svg|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;};

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

<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 = await html2canvas(dom, {  useCORS: true,  scale: 5,});const imageDataURL = canvas.toDataURL("image/png");const response = await fetch(imageDataURL);const imageArrayBuffer = await response.arrayBuffer();const imgDataDict: Record<string, ArrayBuffer> = {  xgq: imageArrayBuffer,};const docxData = await fetch(docx);const docxArrayBuffer = await docxData.arrayBuffer();const zip = new PizZip(docxArrayBuffer);const doc = new Docxtemplater(zip, {  paragraphLoop: true,  linebreaks: true,  modules: [    new ImageModule({      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");

点击全文阅读


本文链接:http://zhangshiyu.com/post/168770.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 全书浏览一见青山云端月(苏浅歌沈廷淮)_一见青山云端月(苏浅歌沈廷淮)全书结局
  • 你来时风起云涌(陆翊夏天瑜赵歆)
  • [错认女儿后,前未婚夫跪求我当平妻]全文+后续_沈意宁宁沈母全集阅读
  • (姜若凝楚淮舟剜月寄无书)剜月寄无书姜若凝楚淮舟全书+后续免费全书_姜若凝楚淮舟剜月寄无书_笔趣阁(剜月寄无书姜若凝楚淮舟全书+后续)
  • (番外)+(结局)时星祁宸衍(离谱!被死对头强娶豪夺了全书+番外+后续)_(时星祁宸衍)列表_笔趣阁(离谱!被死对头强娶豪夺了全书+番外+后续)
  • 往梦难复温创作编写列表_往梦难复温创作编写(沈淮霆宋思予)
  • 「爱意破碎,只留风雨」删减内容修复版本_白玥陈致恒万宁情感冲突名场面试读章
  • (沈淮霆宋思予往梦难复温)往梦难复温沈淮霆宋思予全书+后续免费全书_沈淮霆宋思予往梦难复温_笔趣阁(往梦难复温沈淮霆宋思予全书+后续)
  • [如果回到曾经,我也不会选你]关键剧情节选解锁_「沈辞柳妙湘大屏幕」最新章节免费阅读
  • 爱意消散于那夜免费试读_司南袁宁文修最新章节免费阅读
  • (番外)+(全书)往梦难复温全书++番外(沈淮霆宋思予)完结_(沈淮霆宋思予)列表_笔趣阁(往梦难复温全书++番外)
  • 春到南楼雪尽处优质全章(傅庭州苏枝夏)_春到南楼雪尽处优质全章

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1