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

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

  1. 安装所需库
bash 复制代码
npm install pizzip docxtemplater file-saver
  1. 准备 Word 模板
    创建一个 .docx 文件作为模板,例如 template.docx。在模板中,可以使用类似 {name}、{age} 这样的占位符表示需要替换的数据。
  2. 编写代码将数据插入模板并下载
javascript 复制代码
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 文件。

参考来源

相关推荐
C澒4 分钟前
FE BLL 架构:前端复杂业务的逻辑治理方案
前端·架构·前端框架·状态模式
止观止14 分钟前
拒绝“都是 string”:品牌类型与领域驱动设计 (DDD)
前端·typescript
芸简新章21 分钟前
微前端:从原理到实践,解锁复杂前端架构的模块化密码
前端·架构
pusheng202535 分钟前
燃料电池电化学传感器在硫化物固态电池安全监测中的技术优势解析
前端·人工智能·安全
それども35 分钟前
Excel文件解析 - SAX和DOM方式的区别
java·前端·excel
それども38 分钟前
Excel文件解析 - SAX startRow cell endRow 执行顺序
java·前端·excel
Byron070739 分钟前
基于 Vue 的微前端架构落地实战:从 0 到 1 搭建企业级多应用体系
前端·vue.js·架构
一位搞嵌入式的 genius40 分钟前
从 URL 到渲染:JavaScript 性能优化全链路指南
开发语言·前端·javascript·性能优化
芭拉拉小魔仙40 分钟前
Vue 3 组合式 API 详解:告别 Mixins,拥抱函数式编程
前端·javascript·vue.js
别叫我->学废了->lol在线等40 分钟前
taiwindcss的一些用法
前端·javascript