前端js实现把网页导出为pdf
创始人
2024-12-26 17:09:28
0

前段时间遇到一个需求,产品说需要把当前页面,点击导出按钮,导出为pdf,所以就有了以下代码:
部分来自于官方直连GPT4o

import $ from "jquery"; import html2canvas from 'html2canvas'; import jsPDF from 'jspdf'  export default {     data () {         return {}     },     mounted() {              },     methods: {         formatterPdfElement($dom) {             var $copyElement = $dom.cloneNode(true);             document.querySelector('.export-preview-container').appendChild($copyElement);             this.visiblePreview = true;             this.$nextTick(() => {                 var results = [{                     position: 0,                     height: 0                 }];                 var pageOffsetTop = $copyElement.offsetTop;                 var pageOffsetWidth = $copyElement.offsetWidth;                 // var $unitElements = $($copyElement).find('.minimum-unit'); // 遍历所有子元素不可取,应只遍历第一层子元素                 var $unitElements = $($copyElement).children(); // 遍历所有子元素不可取,应只遍历第一层子元素                 var perPageHeight = pageOffsetWidth / 595.28 * 841.89;                 let tHeight = perPageHeight;                 let insertList = [];                 $unitElements.each((index, $element) => {                     console.log(tHeight, 'tHeight');                     console.log($($element), $($element).outerHeight(true));                     tHeight -= $($element).outerHeight(true);                     if (tHeight < 0) {                         let remainHeight = parseInt(tHeight + $($element).outerHeight(true) + 30);                         tHeight = perPageHeight - $($element).outerHeight(true);                         let obj = {index, remainHeight};                         insertList.push(obj);                     }                 });                 insertList.forEach((dif, index) => {                     let remHeight = dif.remainHeight;                     let domObj = document.createElement("div");                     domObj.innerHTML = "";                     domObj.setAttribute("style", `width:100%;height:${remHeight}px`)                     console.log('$unitElements[dif.index] :>> ', $unitElements[dif.index]);                     $unitElements[dif.index].before(domObj);                 })                 console.log($copyElement, "241");                 // return                  var pdf = new jsPDF('', 'pt', 'a4');                 html2canvas($copyElement, {                     useCORS: true,                     scale: 2,                     allowTaint: true,                     background: '#f0f4f7',                     ignoreElements: (element) => {                         if (element.className.indexOf('top-btns') > -1) {                             return true;                         }                         return false;                     }                 }).then(canvas => {                     var contentWidth = canvas.width;                     var contentHeight = canvas.height;                     var pageHeight = contentWidth / 592.28 * 841.89;                     var leftHeight = contentHeight;                     var position = 0;                     var imgWidth = 592.28;                     var imgHeight = 592.28 / contentWidth * contentHeight;                     if (leftHeight < pageHeight) {                         pdf.addImage(canvas.toDataURL('image/jpeg', 1), 'JPEG', 0, position, imgWidth, imgHeight)                     } else {                         while (leftHeight > 0) {                             pdf.addImage(canvas.toDataURL('image/jpeg', 1), 'JPEG', 0, position, imgWidth, imgHeight);                             leftHeight -= pageHeight;                             position -= 841.89;                             if (leftHeight > 0) {                                 pdf.addPage();                             }                         }                     }                 }).then(() => {                     const name = `${this.reportInfo.devPath}-${this.reportInfo.startDtm}~${this.reportInfo.endDtm}`;                     pdf.internal.scaleFactor = 1.33;                     pdf.save(`${name}.pdf`);                     this.isExporting = false;                     this.visiblePreview = false;                 });             })         },         exportReport() {             var content = document.querySelector('.mian-box-contain');             this.formatterPdfElement(content);         },         /*         *  导出pdf函数         **/         exportReportPdf() {             window.open(this.newUrl)         }     }, }  

相关内容

热门资讯

第9分钟插件!爱趣玩辅助,免费... 第9分钟插件!爱趣玩辅助,免费游戏辅助软件(原来是有辅助下载)-哔哩哔哩进入游戏-大厅左侧-新手福利...
第二分钟手册!wepoker有... 第二分钟手册!wepoker有没有机器人(透视)切实有辅助下载(哔哩哔哩)1、玩家可以在wepoke...
透视练习!wepoker有没有... 透视练习!wepoker有没有插件(透视)开挂脚本辅助器(哔哩哔哩)wepoker有没有插件能透视中...
值得注意的是"福建兄... 值得注意的是"福建兄弟十三水有没有挂"确实存在有辅助器(有挂方式)-哔哩哔哩福建兄弟十三水有没有挂能...
六分钟脚本!全来潜山跑风破解版... 六分钟脚本!全来潜山跑风破解版安卓,乐易四川麻将辅助(真是存在有辅助工具)-哔哩哔哩六分钟脚本!全来...
第九分钟方针!wepoker私... 第九分钟方针!wepoker私人局开挂视频(透视)本来真的是有辅助辅助(哔哩哔哩)亲,关键说明,we...
透视演示!德州局hhpoker... 透视演示!德州局hhpoker(透视)开挂透视安装(哔哩哔哩)小薇(辅助器软件下载)致您一封信;亲爱...
玩家必看攻略"微信小... 玩家必看攻略"微信小程序里的微乐可以开挂吗"一贯是有辅助挂(有挂实锤)-哔哩哔哩1、操作简单,无需微...
2分钟插件!开心十三张技巧,拼... 2分钟插件!开心十三张技巧,拼十辅助器(竟然是真的辅助安装)-哔哩哔哩在进入开心十三张技巧软件靠谱后...
刚刚"雅苑蕲春辅助&... 刚刚"雅苑蕲春辅助"真是是有辅助app(有挂透视)-哔哩哔哩1、下载好雅苑蕲春辅助正确养号方法之后点...