目录
一:PDF生成步骤
1.1 引入所需插件命令
npm install html2canvas npm install jspdf
1.2 在utils中创建pdf.js文件
pdf.js完整代码
// 页面导出为pdf格式 //title表示为下载的标题,html表示document.querySelector('#myPrintHtml')import html2Canvas from 'html2canvas';import JsPDF from 'jspdf'; function htmlPdf(title, html) { html2Canvas(html, { allowTaint: false, taintTest: false, logging: false, useCORS: true, dpi: window.devicePixelRatio * 1, scale: 1 // 按比例增加分辨率 }).then(canvas => { var pdf = new JsPDF('p', 'mm', 'a4'); // A4纸,纵向 var ctx = canvas.getContext('2d'); var a4w = 190; var a4h = 277; // A4大小,210mm x 297mm,四边各保留10mm的边距,显示区域190x277 var imgHeight = Math.floor(a4h * canvas.width / a4w); // 按A4显示比例换算一页图像的像素高度 var renderedHeight = 0; while (renderedHeight < canvas.height) { var 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();// 如果后面还有内容,添加一个空页 } // delete page; } // 保存文件 pdf.save(title + '.pdf'); }); }export default htmlPdf;
1.3 html文件
html完整代码
div里写需要生成的PDF内容的代码
日期 | 姓名 | 地址 |
---|---|---|
{{item.date}} | {{item.name}} | {{item.address}} |
1.4 生成演示
二:PDF分页隔断处理
- 在我们日常开发中生成pdf会遇到内容显示出现隔断问题
- 接下来我会通过代码来处理这个问题
- 思路为获取每一行的高度然后根据页高度来计算此行内容是否超出
- 超出则在上一级兄弟元素添加一个空白块来撑高pad内容
2.1 html代码
- 需要生成的pdf每一行添加一个相同的class作为标识,此次增加的class为“pdf-details”
- 调用htmlPdf方法时需要获取class为“pdf-details”的元素传给pdf.js
html完整代码
div里写需要生成的PDF内容的代码 占位
日期 | 姓名 | 地址 |
---|---|---|
{{item.date}} | {{item.name}} | {{item.address}} |
2.2 pdf.js文件
- 首先获取每一行需要生成的元素来进行遍历
- 根据当前元素以及遍历过的元素总高度来计算出当前元素添加到pdf中是否超出一页
- 超出则添加一个空白块 代替当前元素 当前元素移动到第二页
pdf.js完整代码
// 页面导出为pdf格式 //title表示为下载的标题,html表示document.querySelector('#myPrintHtml')import html2Canvas from 'html2canvas';import JsPDF from 'jspdf';var noTableHeight = 0; //table外的元素高度function htmlPdf(title, html, lableList, type) {// type传有效值pdf则为横版 if (lableList) { const pageHeight = Math.floor(277 * html.scrollWidth / 190) +20; //计算pdf高度 for (let i = 0; i { var pdf = new JsPDF('p', 'mm', 'a4'); // A4纸,纵向 var ctx = canvas.getContext('2d'); var a4w = type ? 277 : 190; var a4h = type ? 190 : 277; // A4大小,210mm x 297mm,四边各保留10mm的边距,显示区域190x277 var imgHeight = Math.floor(a4h * canvas.width / a4w); // 按A4显示比例换算一页图像的像素高度 var renderedHeight = 0; while (renderedHeight < canvas.height) { var 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();// 如果后面还有内容,添加一个空页 } // delete page; } // 保存文件 pdf.save(title + '.pdf'); });} // pdf截断需要一个空白位置来补充function getFooterElement(remainingHeight, fillingHeight = 0) { const newNode = document.createElement('div'); newNode.style.background = '#ffffff'; newNode.style.width = 'calc(100% + 8px)'; newNode.style.marginLeft = '-4px'; newNode.style.marginBottom = '0px'; newNode.classList.add('divRemove'); newNode.style.height = (remainingHeight + fillingHeight) + 'px'; return newNode;}function isSplit(nodes, index, pageHeight) { // 判断是不是tr 如果不是高度存起来 // 表格里的内容要特殊处理 // tr.offsetTop 是tr到table表格的高度 // 所以计算高速时候要把表格外的高度加起来 // 生成的pdf没有表格了这里可以不做处理 直接计算就行 if(nodes[index].localName !== 'tr'){ //判断元素是不是tr noTableHeight+= nodes[index].clientHeight } if(nodes[index].localName !== 'tr'){ return nodes[index].offsetTop + nodes[index].offsetHeight pageHeight; } else { return nodes[index].offsetTop + nodes[index].offsetHeight + noTableHeight pageHeight; }}export default htmlPdf;
2.3 效果
总结
到此这篇关于vue生成pdf文件步骤及pdf分页隔断处理方法的文章就介绍到这了,更多相关vue生成pdf及分页隔断内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!