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

相关内容

热门资讯

德州ai辅助软件!扑克世界辅助... 1、德州ai辅助软件!扑克世界辅助,(德州ai)总是有辅助挂,力荐教程(有挂讲解)2、进入游戏-大厅...
智星德州菠萝有挂吗!poker... 智星德州菠萝有挂吗!pokermaster有德州,(德扑ai)果然真的有挂,透牌教程(有挂揭秘);最...
德州之星插件!德州AI智能辅助... 1、德州之星插件!德州AI智能辅助机器人,智星德州菠萝有挂吗,必胜教程(有挂揭秘)(UU poker...
德州ai辅助软件!红龙扑克有没... 德州ai辅助软件!红龙扑克有没有挂,德扑ai软件,解密教程(有挂教程);支持2-10人实时对战,虚拟...
德州之星插件!红龙扑克辅助工具... 德州之星插件!红龙扑克辅助工具,(红龙扑克)果然有挂辅助挂,透明挂教程(有挂解密)1、玩家可以在红龙...
德州ai辅助软件!扑克世界辅助... 德州ai辅助软件!扑克世界辅助,(红龙扑克)总是是真的有挂,2025新版技巧(有挂方法),支持语音通...
德州之星外挂!德州之星有外 挂... 德州之星外挂!德州之星有外 挂,红龙扑克有没有挂,可靠技巧(有挂方法);最新版2024是一款经典耐玩...
德州ai人工智能!fishpo... 德州ai人工智能!fishpoker下载,(智星德州菠萝)其实有挂辅助挂,透明教程(有挂揭秘);玩家...
德州之星辅助挂!德州之星外挂,... 德州之星辅助挂!德州之星外挂,德州之星外挂,微扑克教程(有挂教程);小薇(透视辅助)致您一封信;亲爱...
德州之星外挂!德州之星辅助,德... 德州之星外挂!德州之星辅助,德州之星插件,必备教程(有挂教程)1、点击下载安装,微扑克wpk插件透视...