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

秦皇岛企业建网站上往建站

秦皇岛企业建网站,上往建站,政府网站建设 互联网,网站怎么做用户登录数据库最近接了个活,需要根据表格数据和用户给定的文档模板,生成报告,因为没得后端,所以做了一个纯前端的生成报告并下载,现实如下: 纯前端根据页面或者后台数据,读取本地文档模板,填充数…

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

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

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.tj-hxxt.cn/news/55966.html

相关文章:

  • 企业网络营销网站互联网推广怎么找客户
  • 做便宜的宝贝的网站2022近期时事热点素材
  • web网站建设方案seo项目完整流程
  • 做网站费用需要分摊吗排名优化怎么做
  • 上海网站制作公司怎么找汕头seo排名收费
  • 重庆网站建设 渝icp平台开发
  • 济南建网站公司seo自学网
  • 备案的网站是公司吗百度网络营销app下载
  • 公司网站怎么突然多了好多友情链接如何删除qq群怎么优化排名靠前
  • 赣州网站建设机构收录是什么意思
  • psd网站排行榜软文广告是什么意思
  • 主流的自助建站网站sem和seo是什么
  • 有关网站建设的网站陕西优化疫情防控措施
  • 企业网站前台静态模板培训机构招生方案
  • 这2个代码 找做网站的 安装一下如何百度推广
  • 福州 网站建设价格微信推广平台收费标准
  • 网站设置不发送消息怎么设置回来高明搜索seo
  • 深圳网站建设深icp备营销策划案的模板
  • 网站怎么做短信营销潍坊关键词优化软件
  • 网站上的平面海报怎么做亚马逊seo关键词优化软件
  • 公司申请网站建设的工作方案网站关键词排名外包
  • 丝袜做那个的视频网站深圳正规seo
  • 代做毕业设计网站家具设计快速建站哪个平台好
  • 业务外包的典型案例长春网站优化体验
  • 宣传型商务网站互联网推广员是做什么的
  • 网站建设前 需要准备的青岛谷歌推广
  • 济南企业上云网站建设关键词搜索引擎
  • 济南网站建设与优化佛山旺道seo
  • 怎么做个网站演示百度收录时间
  • 网站用户体验优化方案免费com域名注册网站