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

html2canvas + JsPDF.js 导出pdf分页时的问题

问题描述

前一段时间 实现了html2canvas + jspdf.js 导出pdf的功能 项目当时没有测试做完就先搁置 最近项目要上线发现分页时问题 这篇文章记录一下之前的bug

import html2canvas from 'html2canvas';
import JsPDF from 'jspdf'
export function savePdf(el,  title) {html2canvas(el, {useCORS: true,allowTaint: true,dpi: 192,//导出pdf清晰度scale:2,}).then(async (canvas) => {// 新建JsPDF对象const pdf = new JsPDF("p", "mm", "a4");let ctx = canvas.getContext('2d'),a4w = 192, a4h = 277,    //A4大小,210mm x 297mm,四边各保留10mm的边距,显示区域190x277imgHeight = Math.floor(a4h * canvas.width / a4w),    //按A4显示比例换算一页图像的像素高度renderedHeight = 0;while(renderedHeight < canvas.height) {let page = document.createElement("canvas");page.width = canvas.width;page.height = Math.min(imgHeight, canvas.height - renderedHeight);//可能内容不足一页//用getImageData剪裁指定区域,并画到前面创建的canvas对象中page.getContext('2d').putImageData(ctx.getImageData(0, renderedHeight, canvas.width, Math.min(imgHeight, canvas.height - renderedHeight)), 0, 0);pdf.addImage(page.toDataURL('image/jpeg', 1.0), 'JPEG', 10, 10, a4w, Math.min(a4h, a4w * page.height / page.width));    //添加图像到页面,保留10mm边距renderedHeight += imgHeight;if(renderedHeight < canvas.height)pdf.addPage();//如果后面还有内容,添加一个空页page = null}pdf.save(title + ".pdf");}).catch((e) => {console.log(e)}).finally(() => {});
}

在这里插入图片描述

分页的pdf 就能正常的展示

参考地址: https://www.cnblogs.com/BoyTNT/p/11711439.html

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

相关文章:

  • Linux系统Docker部署StackEdit Markdown并实现公网访问本地编辑器
  • 从Spring Boot应用上下文获取Bean定义及理解其来源
  • 如何处理网络攻击对系统造成的损害?
  • 数字IC后端设计利器 - 《Innovus的基本使用流程和命令》(附下载)
  • Blender中四种不同的几何体类型(网格、曲线、体积和实例 )
  • Vue3 学习笔记(Day5)
  • 【网络编程】实现服务器端和客户端的通讯的简单程序
  • 如何在Portainer中部署Nginx容器并制作一个本地站点结合cpolar发布至公网可访问
  • Mysql的储存引擎
  • 【查漏补缺你的Vue基础】Vue数据监听深度解析
  • 大语言模型LLM发展历程中的里程碑项目:国内外技术革新重塑自然语言处理(LLM系列02)
  • JS二进制文件转换:File、Blob、Base64、ArrayBuffer
  • 编译opencv gpu版的条件
  • List集合的Stream流式操作实现数据类型转换
  • Ubuntu 20.04.6 LTS下edge浏览器点击图标没反应
  • php基础学习之错误处理(其一)
  • Nginx 解析漏洞复现
  • JQMobile Loader Widget 遮罩层改造
  • 练习 2 Web [ACTF2020 新生赛]BackupFile 1
  • 【python】subprocess用法示例
  • Socket网络编程(三)——TCP快速入门
  • 皇冠测评:网络电视盒子哪个品牌好?电视盒子排行榜
  • simple-pytest 框架使用指南
  • React中使用useActive
  • ElasticSearch安装和kibana控制台安装
  • VSCode安装与使用详细教程
  • 土壤墒情监测站的工作原理
  • Flutter 多标签页显示 有关TabController需要知道的知识
  • 【Elasticsearch专栏 16】深入探索:Elasticsearch的Master选举机制及其影响因素分析
  • Leetcode : 215. 数组中的第 K 个最大元素