vue3 使用docxtemplater 动态生成docx

模版文件docx放到vue工程public下

文件内容

vue文件

html 复制代码
<template>
  <div>
    <button @click="generateDocument">生成Word文档</button>
  </div>
</template>

<script>
import PizZip from 'pizzip';
import Docxtemplater from 'docxtemplater';
import { saveAs } from 'file-saver';
import PizZipUtils from 'pizzip/utils/index.js';

function loadFile(url, callback) {
  PizZipUtils.getBinaryContent(url, callback);
}

export default {
  methods: {
    generateDocument() {
      // 假设你的模板文件位于 public 文件夹下
      const templatePath = '/docx/tepmlate/testtemplate2.docx'; // 替换为你的模板路径
      
      loadFile(templatePath, (error, content) => {
        if (error) throw error;

        const zip = new PizZip(content);
        const doc = new Docxtemplater(zip, {
          paragraphLoop: true,
          linebreaks: true,
        });

        // 渲染文档,替换占位符
        doc.render({
          first_name: 'John'
        });

        // 生成Blob文件
        const blob = doc.getZip().generate({ type: 'blob' });
        // 下载文件
        saveAs(blob, 'output.docx');
      });
    }
  }
}
</script>

相关推荐
火星思想2 分钟前
React为何选择宏任务而非微任务进行任务调度?
前端
前端服务区3 分钟前
React内置Hooks
前端·react.js
前端花园3 分钟前
前端开发AI Agent之Memory理论篇
前端·aigc·trae
一只小风华~3 分钟前
web前端开发:CSS的常用选择器
前端·css·html·html5
啊吧啊吧曾小白4 分钟前
聊一聊前端日常使用的try...catch...finally
前端·javascript·面试
工呈士5 分钟前
HTML语义化与无障碍设计
前端·html
海底火旺6 分钟前
前端面试必考!== 和 === 的区别及最佳实践全解析
前端·javascript
几何心凉7 分钟前
企业数据采集新实践:提升工作效率的秘籍
前端·javascript
zayyo9 分钟前
前端性能优化:图片懒加载全攻略
前端·面试·性能优化
用户800052697756911 分钟前
思维导图前端实现
前端