vue项目页面生成PDF并下载

2020-09-03  本文已影响0人  _皓月__

htmlToPdf.js

// 导出页面为PDF格式
import html2Canvas from "html2canvas";
import JsPDF from "jspdf";
/**
 * 用法:this.$getPdf("id","PDF名字");
 * @param {String} idStr 要打印的DOM区域 id
 * @param {String} title 导出的pdf文件名称
 */
const getPdf = function(idStr, title) {
  html2Canvas(document.querySelector("#" + idStr), {
    allowTaint: true
  }).then(function(canvas) {
    let contentWidth = canvas.width;
    let contentHeight = canvas.height;
    let pageHeight = (contentWidth / 592.28) * 841.89;
    let leftHeight = contentHeight;
    let position = 0;
    let imgWidth = 595.28;
    let imgHeight = (592.28 / contentWidth) * contentHeight;
    let pageData = canvas.toDataURL("image/jpeg", 1.0);
    let 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");
  });
};

export default { getPdf };

然后在main.js中使用定义的htmlToPdf.js文件:

import htmlToPdf from '@/components/htmlToPdf.js'
Vue.prototype["$getPdf "] = htmlToPdf.getPdf;
上一篇下一篇

猜你喜欢

热点阅读