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

前端生成docx文档、excel表格、图片、pdf文件

一、前端将页面某区域内容下载为word文档:html-to-docx、file-saver插件组合使用
import HTMLtoDOCX from 'html-to-docx';
import { saveAs } from 'file-saver';const exportTest = async () => {const fileBuffer = await HTMLtoDOCX(`<h2>文件标题</h2><br>文件内容222`,null,{table: { row: { cantSplit: true } },footer: true,pageNumber: true,font: '-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji',},);saveAs(fileBuffer, `测试下载文件.docx`);}
二、前端将数据导出成excel表格:XLSX插件
import * as XLSX from 'xlsx';const downloadExcel = () => {const tableRows = [{‘表头1’:‘111’, ‘name’: 'zhangsan '}]const sheet = XLSX.utils.json_to_sheet(tableRows); //此处为表格的数据const wb = XLSX.utils.book_new();XLSX.utils.book_append_sheet(wb, sheet);XLSX.writeFile(wb, `${date.getTime()}.xlsx`);};
三、页面区域导出为图片:html2canvas插件
import html2canvas from 'html2canvas';
import { useEffect, useRef } from 'react';export const TestPage = () => {
const testRef = useRef(null);const html2image = (url: any, fileName: any) => {// 创建一个虚拟的a标签let link = document.createElement('a');link.href = url;link.download = fileName;document.body.appendChild(link);// 触发点击事件进行下载link.click();// 下载完成后删除a标签setTimeout(function () {document.body.removeChild(link);}, 100);
};const downloadImg = () => {const dom = testRef.current;html2canvas(dom, {useCORS: true,allowTaint: true,}).then((canvas: any) => {const url = canvas.toDataURL('image/png');html2image(url, new Date().getTime().toString());});};return (<><div onClick={() =>{downloadImg ()}}>导出</div><div ref={testRef}>需要导出的页面区域</div></>
)
}
四、前端导出为pdf文件:jsPDF 
import jsPDF from 'jspdf';
const htmlStringToPdf = async (dom: HTMLElement, name: string) => {html2canvas(dom, {scale: 1,y: -10,}).then((canvas: any) => {const imgWidth = 200;const pageHeight = 300;const imgHeight = (canvas.height * imgWidth) / canvas.width;let heightLeft = imgHeight;let position = 0;heightLeft -= pageHeight;const doc = new jsPDF('p', 'mm', 'a4');doc.addImage(canvas, 'PNG', 0, position, imgWidth, imgHeight, '', 'FAST');while (heightLeft >= 0) {position = heightLeft - imgHeight;doc.addPage();doc.addImage(canvas, 'PNG', 0, position, imgWidth, imgHeight, '', 'FAST');heightLeft -= pageHeight;}doc.save(`${name}.pdf`);});
};

http://www.lryc.cn/news/508357.html

相关文章:

  • c++---------流类
  • 3、基本复用原理和复用单元
  • Vue与React:前端框架的巅峰对决
  • Java 中的面向对象编程 (OOP) 概念
  • 十二月第20讲:Python中指数概率分布函数的绘图详解
  • 汽车IVI中控开发入门及进阶(44):杰发科智能座舱芯片
  • 【py脚本+logstash+es实现自动化检测工具】
  • Zookeeper的选举机制
  • 2024-05-18 前端模块化开发——ESModule模块化
  • Linux IPV6 地址配置 | IPv6 禁用 | ping6 过程细节剖析 | IPv6 排障
  • 【YashanDB知识库】XMLAGG方法的兼容
  • echarts加载区域地图,并标注点
  • echarts画风向杆
  • 【LeetCode每日一题】LeetCode 345.反转字符串中的元音字母
  • 蓝桥杯练习生第四天
  • cesium 常见的 entity 列表
  • Java旅程(五)Spring 框架与微服务架构 了解 JVM 内部原理和调优
  • Niushop-master靶场漏洞
  • 35道面向初中级前端的基础面试题
  • MFC用List Control 和Picture控件实现界面切换效果
  • 1. 解决前端vue项目 vite打包内存溢出问题
  • Springboot高并发乐观锁
  • 【WPS安装】WPS编译错误总结:WPS编译失败+仅编译成功ungrib等
  • pytorch MoE(专家混合网络)的简单实现。
  • 虚拟机VMware的安装问题ip错误,虚拟网卡
  • Linux下基于最新稳定版ESP-IDF5.3.2开发esp32s3入门hello world输出【入门一】
  • 重温设计模式--命令模式
  • 电力通信规约-104实战
  • 什么是事务
  • 数据结构:双向循坏链表