前端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)         }     }, }  

相关内容

热门资讯

透视苹果版!wpk作弊是真的吗... 透视苹果版!wpk作弊是真的吗,wpk德州局透视,2025新版技巧(都是存在有挂);所有人都在同一条...
透视代打!we poker插件... 透视代打!we poker插件,wepoker插件程序激活码(本来是真的有挂)1、完成wepoker...
透视规律!wpk辅助器,wpk... 透视规律!wpk辅助器,wpk透视辅助靠谱吗,透明教程(一贯是真的有挂)1、起透看视 wpk透视辅助...
透视软件!wepoker有没有... 透视软件!wepoker有没有插件,wepoker软件辅助程序(一直是真的有挂);1、金币登录送、破...
透视教学!wpk安卓下载辅助,... 透视教学!wpk安卓下载辅助,wpk官网下载链接,新版2025教程(其实真的是有挂);1、点击下载安...
透视免费!wepoker黑侠辅... 透视免费!wepoker黑侠辅助器,wepoker好友房开挂(竟然存在有挂)1、wepoker好友房...
透视插件!wepoker怎么挂... 透视插件!wepoker怎么挂飞机,wepoker怎么买辅助(原来真的是有挂);1、透视插件!wep...
透视辅助!wpk私人辅助,wp... 透视辅助!wpk私人辅助,wpk控制牌是真的吗,技巧教程(都是是有挂)1、wpk控制牌是真的吗ai机...
透视中牌率!WePOker有没... 透视中牌率!WePOker有没有透视方法,wepoker辅助器激活码(都是有挂)所有人都在同一条线上...
透视计算!wpk作弊,如何判断... 透视计算!wpk作弊,如何判断wpk辅助软件的真假,第三方教程(总是是真的有挂)如何判断wpk辅助软...