vue项目纯前端实现导出pdf文件

server/2024/9/22 17:34:16/

1、下载插件

npm install html2canvas
npm install jspdf

2、创建htmlToPdf.js,地址:src/utils/htmlToPdf.js

import html2Canvas from 'html2Canvas'  
import JsPDF from 'jspdf'  export default {  install(Vue, options) {  Vue.prototype.getPdfFromHtml = function (eleId, pdfFileName, hide) {  // 确保传入了正确的元素ID  const ele = document.getElementById(eleId);  if (!ele) {  console.error('No element found with ID:', eleId);  return;  }  pdfFileName = pdfFileName || "pdf";  // 滚动置顶(如果需要)  window.pageYOffset = 0; // 或者使用 window.scrollTo(0, 0);  // ... 其他可能的滚动设置(如果有)  // 使用html2canvas捕获元素并转换为canvas  html2Canvas(ele, {  dpi: window.devicePixelRatio * 2, // 根据需要调整DPI  useCORS: true, // 允许跨域图片  // ... 其他选项  }).then(canvas => {  // 隐藏加载消息(如果有)  this.$message.closeAll(); // 假设您使用的是Element UI的message组件  // 创建PDF文档并添加canvas内容  const pdf = new JsPDF('p', 'mm', 'a4'); // 使用A4纸,横向  const imgProps = pdf.getImageProperties(canvas.toDataURL('image/png'));  // 根据需要添加多页内容(如果需要)  let heightLeft = imgProps.height;  const top_left_margin = 10; // 您可以根据需要调整边距  const pdfWidth = pdf.internal.pageSize.getWidth() - 2*top_left_margin;  const pdfHeight = pdf.internal.pageSize.getHeight() - 2*top_left_margin;  while(heightLeft > 0) {  pdf.addImage(canvas.toDataURL('image/png'), 'PNG', top_left_margin, top_left_margin, pdfWidth, Math.min(pdfHeight, heightLeft));  if (heightLeft > pdfHeight) {  pdf.addPage();  }  heightLeft -= pdfHeight;  // 如果需要,可以在此处添加页眉/页脚等  }  // 保存PDF  pdf.save(pdfFileName + '.pdf');  }).catch(error => {  console.error('Error generating PDF:', error);  // 显示错误消息(如果需要)  this.$message.error('生成PDF时出错');  });  };  }  
};

3、main.js中引入

import htmlToPdf from './utils/htmlToPdf.js'Vue.use(htmlToPdf)

4、vue页面中使用

在需要打印的块元素上边添加id='pdfDom'

this.GetPdfFromHtml('pdfDom',this.name)


http://www.ppmy.cn/server/53508.html

相关文章

基于STM32的PWM实现LED调光效果详解

STM32单片机PWM引脚的使用详解 引言 STM32单片机是现代嵌入式系统中广泛使用的微控制器系列之一。它以其高性能、低功耗和丰富的外设资源而著称。在众多外设中,PWM(脉宽调制)功能尤为重要,广泛应用于电机控制、LED调光、音频信号生…

医学预测模型web APP的制作建议

医学预测模型web APP的制作建议 医学预测模型类web APP定义为承载预测模型而便利预测模型临床应用的可视化客户端。 医学预测模型类web APP的功能是衔接预测模型和临床实践,让用户正确地,方便地使用预测模型并恰当地理解预测模型的结果,在此…

资料导览(持续更新)

经典推荐 多模态大模型:基础架构 图解DSPy:Prompt的时代终结者?! vLLM, LMDeploy, MLC-LLM, TensorRT-LLM, and TGI的性能小实验 优雅谈大模型13:一文读懂LoRA/DoRA/MoRA 新鲜速递:图解新颖LLM的CoPE位…

【python - 数据】

一、序列 序列(sequence)是一组有顺序的值的集合,是计算机科学中的一个强大且基本的抽象概念。序列并不是特定内置类型或抽象数据表示的实例,而是一个包含不同类型数据间共享行为的集合。也就是说,序列有很多种类&…

设计模式 - Observer Pattern 观察者模式

文章目录 定义观察者模式的实现构成构成UML图 观察者模式的代码实现场景代码实现 总结优点缺点应用场景 其他设计模式文章: 定义 观察者模式是行为型模式的一种,它定义对象间的一种一对多的依赖关系,使得每当一个对象改变状态,它…

Retrieval-Augmented Generation for Large Language Models A Survey

Retrieval-Augmented Generation for Large Language Models: A Survey 文献综述 文章目录 Retrieval-Augmented Generation for Large Language Models: A Survey 文献综述 Abstract背景介绍 RAG概述原始RAG先进RAG预检索过程后检索过程 模块化RAGModules部分Patterns部分 RAG…

[数据集][目标检测]电力场景下电柜箱门把手检测数据集VOC+YOLO格式1167张1类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):1167 标注数量(xml文件个数):1167 标注数量(txt文件个数):1167 标注…

《重构》读书笔记【第1章 重构,第一个示例,第2章 重构原则】

文章目录 第1章 重构,第一个示例1.1 重构前1.2 重构后 第2章 重构原则2.1 何谓重构2.2 两顶帽子2.3 为何重构2.4 何时重构2.5 重构和开发过程 第1章 重构,第一个示例 我这里使用的IDE是IntelliJ IDEA 1.1 重构前 plays.js export const plays {&quo…