小程序开发|小程序制作|小程序开发网

搜索

vue导出pdf(大数量可能有问题)

2023-3-15 22:16| 发布者: yangyuan| 查看: 307| 评论: 0

摘要: 1.首先创建js文件exportPdf.js,且需要安装html2canvas和jspdf两个插件;然后将在你需要导出的页面中执行方法,this.getPdf("html", "报表");//参数一:导出范围的id//参数二:导出pdf文件的名称下面是导出的主要代码

1.首先创建js文件exportPdf.js,且需要安装html2canvas和jspdf两个插件;
然后将在你需要导出的页面中执行方法,

this.getPdf("html", "报表");//参数一:导出范围的id//参数二:导出pdf文件的名称

下面是导出的主要代码;我在网上查找了大量的代码才写出了这个,其他的代码都是很浅显,虽然也可以导出,但是一旦数据量过大,页面较长导出的pdf文件便会白屏;此文件解决了此问题,但是因为导出的pdf做了分页,而pdf又是由图片转换而来,所以分页中会有截断的问题,暂未解决,希望大家可以指点。

/* 导出pdf文档 */import html2Canvas from "html2canvas";import JsPDF from "jspdf";export default { install(Vue, options) {   Vue.prototype.getPdf = function (id, title) {     const loading = Vue.prototype.$loading({       fullscreen: true,       lock: true,       text: 'Loading',       spinner: 'el-icon-loading',       background: 'rgba(0, 0, 0, 0.7)'     });     let shareContent = document.getElementById(id), //需要截图的包裹的(原生的)DOM 对象       width = shareContent.clientWidth, //获取dom 宽度       height = shareContent.clientHeight, //获取dom 高度       canvas = document.createElement("canvas"), //创建一个canvas节点       scale = 1; //定义任意放大倍数 支持小数     canvas.width = width * scale; //定义canvas 宽度 * 缩放     canvas.height = height * scale; //定义canvas高度 *缩放     canvas.style.width = shareContent.clientWidth * scale + "px";     canvas.style.height = shareContent.clientHeight * scale + "px";     canvas.getContext("2d").scale(scale, scale); //获取context,设置scale     let opts = {       scale: scale, // 添加的scale 参数       canvas: canvas, //自定义 canvas       logging: false, //日志开关,便于查看html2canvas的内部执行流程       width: width, //dom 原始宽度       height: height,       useCORS: true, // 【重要】开启跨域配置     }     html2Canvas(shareContent, opts).then(() => {       var contentWidth = canvas.width;       var contentHeight = canvas.height;       //一页pdf显示html页面生成的canvas高度;       var pageHeight = (contentWidth / 592.28) * 841.89;       //未生成pdf的html页面高度       var leftHeight = contentHeight;       //页面偏移       var position = 0;       //a4纸的尺寸[595.28,841.89],html页面生成的canvas在pdf中图片的宽高       var imgWidth = 595.28;       var imgHeight = (592.28 / contentWidth) * contentHeight;       var pageData = canvas.toDataURL("image/jpeg", 1.0);       var PDF = new JsPDF("", "pt", "a4");       if (leftHeight < pageHeight) {         PDF.addImage(pageData, "JPEG", 0, 0, imgWidth, imgHeight);       } else {         while (leftHeight > 0) {           PDF.addImage(pageData, "JPEG", 0, position, imgWidth, imgHeight);           leftHeight -= pageHeight;           position -= 841.89;           if (leftHeight > 0) {             PDF.addPage();           }         }       }       PDF.save(title + ".pdf"); // 这里是导出的文件名       loading.close();       this.$router.go(-1)     });   }; }};

注意:打印的时候,父级或者父级之上的元素的css设置不能有transform,否则在火狐浏览器中,打印出来的pdf会有偏移。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

鲜花

握手

雷人

路过

鸡蛋

最新评论

返回顶部