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

vue3生成pdf

# 安装稳定版本 npm install html2canvas1.4.1 jspdf1.5.3divdiv refcontentRef classcertificate-contentdiv classtitle标题/divdiv内容/div/divdiv classbottom-btnbutton clickdownLoadPDF生成PDF/button/divdivscript langts setupimport {ref,reactive,PropType,watch,defineProps,defineEmits,onMounted,computed,} from vue;const contentRef ref();const loading ref(false);import html2canvas from html2canvas;import jsPDF from jspdf;const downLoadPDF async () {if (!contentRef.value) {console.log(contentRef.value 为空);return;}loading.value true;try {//1. 将DOM节点转换为Canvas图像const canvas await html2canvas(contentRef.value, {scale: 2, //提高分辨率让PDF更清晰backgroundColor: #fff,logging: false,useCORS: true, //如果内容中有图片需要开启跨域支持});const imgData canvas.toDataURL(image/png);//2. 创建 PDF 文档A4纸尺寸纵向const pdf new jsPDF({orientation: portrait,unit: mm,format: a4,});//3.计算图像在PDF中的尺寸const pdfWidth pdf.internal.pageSize.getWidth(); // A4 宽度约 210mmconst pdfHeight pdf.internal.pageSize.getHeight(); // A4 高度约297mmconst imgWidth pdfWidth;const imgHeight (canvas.height * imgWidth) / canvas.width;//4. 将图像添加到 PDF 中pdf.addImage(imgData, PNG, 0, 0, imgWidth, imgHeight, undefined, FAST);//5. 保存PDF,pdf.save(XXX.pdf);} catch (err) {console.log(生成PDF失败, err);} finally {loading.value false;}};/scriptstyle scoped.certificate-content {padding: 80px;font-family: SimSun, 宋体, serif;font-size: 16px;white-space:pre-wrap;white-space:pre-line;}.title{text-align: center;margin-bottom: 100px;font-size:30px;}.bottom-btn{text-align: right;}/style
http://www.gsyq.cn/news/1344259.html

相关文章:

  • OPA 策略管理实践:从策略到执行
  • 游戏引擎选型实战指南:聚焦团队匹配与项目生命周期
  • Palantir 现在干的活,本质上就是你描述的那个方向,但它在“深度”和“广度”上比你目前的 MVP 设想走得更远。如果说你想做的是一个“能听懂人话的 SQL 查询工具”,那么 Palantir
  • 谁能推荐几个能替代进口品牌的光学筛选机直驱电机供应商?
  • 华硕笔记本的轻量级遥控器:G-Helper让硬件控制回归简单
  • 3MF转GLTF完整技术文档(含免费在线转换教程)
  • 终极NHSE存档编辑器:专业级动物森友会存档修改实战指南
  • 当“信任”成为最大的安全盲区
  • 软件模拟iic+BL24C512
  • SketchUp STL插件终极指南:高效实现3D打印模型转换的完整实战方案
  • 基于Java Web的退休人才求职网站设计与开发
  • 米哈游游戏字体完整指南:11款精美架空文字字体一键获取与使用
  • 一周AI新鲜事(2026.05.11—2026.05.17):AI世界正在进入“全面战争时代”
  • 科技中介机构如何提升服务效率与转化率?
  • java springboot-vue的婚庆服务平台的功能设计
  • Mos:macOS 鼠标滚轮太生硬?这款免费开源工具让你的滚轮爽如触控板
  • 蓝绿环境 灰度环境 极简区别
  • 如何免费实现本地视频字幕提取:你的完整指南
  • QGraphicsView的记录
  • (Pytorch、pandas、matplotlib)数据操作
  • 手机上还有免费编辑pdf文本的软件?!
  • 3分钟掌握PlantUML Editor:用代码思维绘制专业UML图表的终极指南
  • 短信验证码5大常见漏洞与防御实战
  • 罗技鼠标宏压枪脚本:基于Lua的游戏后坐力控制系统架构
  • 现代Qt开发教程(新手篇)2.4——QFont 与文本渲染基础
  • ViGEmBus虚拟游戏控制器驱动:Windows游戏输入的终极解决方案
  • CANN 异构编程:CPU-NPU 协同计算实战
  • Unity动态设置Layer与摄像机屏蔽的完整闭环方案
  • FreeMove终极指南:Windows磁盘空间优化利器,轻松释放C盘数十GB空间
  • NGINX明文注入漏洞CVE-2026-1642原理与防御实战