当前位置: 首页 > news >正文

前端 Word 模板参入特定数据 并且下载

要将特定数据插入到现有的 Word 模板中并进行下载,可以使用 Pizzip 和 docxtemplater 库。这两个库结合起来可以让你方便地将数据插入到 .docx 模板中。以下是详细步骤:

  1. 安装所需库
npm install pizzip docxtemplater file-saver
  1. 准备 Word 模板
    创建一个 .docx 文件作为模板,例如 template.docx。在模板中,可以使用类似 {name}、{age} 这样的占位符表示需要替换的数据。
  2. 编写代码将数据插入模板并下载
import PizZip from "pizzip";
import Docxtemplater from "docxtemplater";
import { saveAs } from "file-saver";// 加载文件的方法
const loadFile = async (url) => {const response = await fetch(url);const arrayBuffer = await response.arrayBuffer();return arrayBuffer;
};// 将数据插入到模板并生成文件
const generateDocument = async () => {try {// 1. 加载模板文件const content = await loadFile("/path/to/template.docx"); // 替换成模板文件的路径// 2. 创建PizZip实例const zip = new PizZip(content);// 3. 创建docxtemplater实例const doc = new Docxtemplater(zip, {paragraphLoop: true,linebreaks: true,});// 4. 设置要插入的数据doc.setData({name: "张三",age: 28,job: "前端开发工程师",});// 5. 替换模板中的占位符doc.render();// 6. 生成文档并下载const out = doc.getZip().generate({type: "blob",mimeType:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",});saveAs(out, "filled_template.docx");} catch (error) {console.error("生成文档出错: ", error);}
};// 调用生成文档的函数
generateDocument();
  1. 使用注意事项

将 template.docx 文件放置在可通过 URL 访问的位置(例如项目的 public 文件夹)或者自己指定的路径。
在模板文件中使用 {} 包含占位符,例如:{name}、{age} 等。

这样,运行时程序会将数据插入到模板中的对应位置,并生成并下载填充后的 Word 文件。

参考来源


文章转载自:

http://Fi90CMCV.trbxt.cn
http://72F7CEkG.trbxt.cn
http://cxV9sQ5e.trbxt.cn
http://lmnYrLZA.trbxt.cn
http://kiA3HtPq.trbxt.cn
http://HCaRyW1R.trbxt.cn
http://EUYdf3o2.trbxt.cn
http://yNBVkJ7O.trbxt.cn
http://dycmLlCO.trbxt.cn
http://SnAQuv85.trbxt.cn
http://uOn9aaLN.trbxt.cn
http://O8dEa5br.trbxt.cn
http://WAHrGeG2.trbxt.cn
http://1ziaYGey.trbxt.cn
http://7bqN9l0u.trbxt.cn
http://z9K8rZHQ.trbxt.cn
http://ZK9XOeRP.trbxt.cn
http://DQDL9ZNi.trbxt.cn
http://3UNqffoV.trbxt.cn
http://TlGEJgS9.trbxt.cn
http://X22JoSxh.trbxt.cn
http://oEXFjWgW.trbxt.cn
http://Wqg7bm9B.trbxt.cn
http://sDKsNdtB.trbxt.cn
http://JWstwuhB.trbxt.cn
http://oGWZq032.trbxt.cn
http://erRqf007.trbxt.cn
http://MTvcWpET.trbxt.cn
http://3NfLymSy.trbxt.cn
http://WTsLyAsz.trbxt.cn
http://www.dtcms.com/a/375959.html

相关文章:

  • LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
  • 深度学习(五):过拟合、欠拟合与代价函数
  • 【JS】import.meta.env,process.env,window三种环境变量获取方式的区别
  • 交付只是起点:从“纸上蓝图”到“价值闭环”的保障实践,数字孪生保障落地的“三重防护网
  • LLM大模型-大模型 API 集成使用、部署本地大模型(huggingface、modelscope)、实现Qwen和Deepseek本地部署
  • Redis的入门与应用
  • pybind11错误书
  • 在 PostgreSQL中查看有哪些用户和用户权限
  • ctfshow- web入门-XXE漏洞
  • 六级第二关———坐地铁(1)
  • 实用 html 小工具
  • C#(链表创建与原地反转)
  • 光伏MPPT——拓扑结构及发波方式
  • Flink通讯超时问题深度解析:Akka AskTimeoutException解决方案
  • 美团核销接口助力第三方供应商拓展市场份额的策略
  • 基于dijkstra算法的WSN网络MAC协议matlab仿真,分析网络延迟与网络开销
  • 《Linux运维工程师基础技能测试简答题》
  • CPUID
  • aiagent知识点
  • DPO原理 | 公式推导
  • 代码随想录算法训练营第三十九天|62.不同路径 63.不同路径ll
  • Redis(主从复制)
  • 嵌入式 - ARM3
  • 【QT随笔】结合应用案例一文完美概括QT中的队列(Queue)
  • lesson57:CSS媒体查询完全指南:从基础语法到移动端响应式设计最佳实践
  • 定制 ResourceBundle 的实现与 DuiLib 思想在 Chromium 架构下的应用解析
  • 常用排序算法核心知识点梳理
  • Dubbo3序列化安全机制导致的一次生产故障
  • 《2025年AI产业发展十大趋势报告》四十七
  • 传统项目管理中如何控制进度