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

vue纯前端根据页面或者后台数据,读取本地文档模板,填充数据后并导出

最近接了个活,需要根据表格数据和用户给定的文档模板,生成报告,因为没得后端,所以做了一个纯前端的生成报告并下载,现实如下:

纯前端根据页面或者后台数据,读取本地文档模板,填充数据后并导出

1、技术 vue3 + element-plus 或者 vue2 + element-ui
2、安装依赖

npm install docxtemplater
npm install pizzip
npm install file-saver

3、模板文件,以doc为例,放在本地public
在这里插入图片描述
4、具体代码实现(复制可用)

<!-- 前端实现,获取本地文档模板,在页面上根据数据,导出一个有数据的word -->
<template><el-table :data="tableData" style="width: 100%"><el-table-column label="Date" width="180"><template #default="scope"><div style="display: flex; align-items: center"><el-icon><timer /></el-icon><span style="margin-left: 10px">{{ scope.row.date }}</span></div></template></el-table-column><el-table-column label="Name" width="180"><template #default="scope"><el-popover effect="light" trigger="hover" placement="top" width="auto"><template #default><div>name: {{ scope.row.name }}</div><div>address: {{ scope.row.address }}</div></template><template #reference><el-tag>{{ scope.row.name }}</el-tag></template></el-popover></template></el-table-column><el-table-column label="Operations"><template #default="scope"><el-button size="small" @click="generateReport(scope.row)">生成报告</el-button><el-button size="small" @click="handleEdit(scope.$index, scope.row)">Edit</el-button><el-button  size="small"  type="danger"  @click="handleDelete(scope.$index, scope.row)">Delete</el-button></template></el-table-column></el-table>
</template><script setup>
// import Docxtemplater from 'docxtemplater'
// import PizZip from 'pizzip'
import { saveAs } from 'file-saver'const tableData = [{date: '2016-05-03',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-02',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-04',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},{date: '2016-05-01',name: 'Tom',address: 'No. 189, Grove St, Los Angeles',},
]
const handleEdit = (index,row ) => {console.log(index, row)
}
const handleDelete = (index, row) => {console.log(index, row)
}const generateReport = async (row) => {console.log(row)try {// 1. 加载Word模板文件console.log(window.origin)const response = await fetch('/mb.docx')const arrayBuffer = await response.arrayBuffer()// 2. 初始化docxtemplater(老版本)// const zip = new PizZip(arrayBuffer)// const doc = new Docxtemplater().loadZip(zip)//新const PizZip = require('pizzip');const Docxtemplater = require('docxtemplater');const zip = new PizZip(arrayBuffer);const doc = new Docxtemplater(zip);// 3. 准备模板数据(根据你的Word模板结构调整)let templateData = {title: '数据分析报告',name:row.name,date:row.date,address:row.address,}// 4. 渲染模板doc.render(templateData)// 5. 生成并下载文件const out = doc.getZip().generate({ type: 'blob' })saveAs(out, `数据分析报告_${new Date().getTime()}.docx`)} catch (error) {console.error('生成报告失败:', error)}
}
</script>

5、点击生成报告结果如下
在这里插入图片描述

http://www.xdnf.cn/news/13972.html

相关文章:

  • Node.js特训专栏-基础篇:3. Node.js内置模块的使用
  • 【工具教程】批量PDF识别提取区域的内容重命名,将PDF指定区域位置的内容提取出来改名的注意事项
  • Vue-生命周期
  • OpenFeign声明式调用实战指南
  • Kubernetes安全机制深度解析(四):动态准入控制和Webhook
  • 前端面试专栏-基础篇:6. 跨域方案全对比(CORS/JSONP/Nginx)与安全攻防
  • Linux驱动学习day4
  • 【Twisted】Python 使用Twisted实现TCP多人聊天Demo
  • 两个矩阵的卷积运算
  • 一个用专业知识库与多层RAG打造调研报告的Agent
  • vue常用框架,及更新内容
  • orb_slam--安装配置
  • C语言二维数组的使用详解
  • C++ —— STL容器 —— string的模拟实现
  • 北京大学:AI+Agent与Agentic+AI的原理与应用(适合科研从业者和技术爱好者阅读)
  • 宝塔面板WordPress中使用Contact Form 7插件收不到邮件的解决方法
  • 【AI论文】MiniCPM4:在终端设备上实现超高效的大型语言模型(LLMs)
  • 突破AI瓶颈:基于实时感知的智能选路实现智算负载均衡优化
  • 【教程】Android(AOSP)Framework开发/ROM定制快速教程
  • 本地部署 DeepSeek-R1-0528 超大语言模型全流程指南(含量化版优化实操)
  • HBase 安装与简单操作指南
  • 深入 Java 泛型:高级应用与实战技巧
  • 深度学习神经网络架构Transformer深刻理解
  • 论文略读:Ask, and it shall be given: On the Turing completeness of prompting
  • OpenCV 鼠标操作与响应之绘制ROI提取图像
  • antd vue a-range-picker如何设置不能选择当前和之后的时间,包含时分秒
  • SSM框架实现学生管理系统的需求分析与设计详解
  • 智能聊天AI Top10 排行榜 - 2025年05月
  • 牛客小白月赛118
  • 计算机图像处理:从像素到卷积与池化的深度解析