将页面生成为pdf并下载(vue版本)

4 篇文章 0 订阅
3 篇文章 0 订阅
npm install JsPDF --save
npm install html2Canvas --save
//在项目的util文件夹下新建htmlToPdf.js

import html2Canvas from "html2canvas";
import JsPDF from "jspdf";
import { Loading } from "element-ui"; //此处根据你实际使用的框架的loading进行引入 
let loading;
export default {
  install(Vue, options) {
    Vue.prototype.getPdf = function(pdfTitle) {
      loading = Loading.service({
        lock: true,
        text: "正在下载pdf...",
        background: "rgba(0,500,200,.5)"
      });
      html2Canvas(document.querySelector("#pdfDom"), {
        allowTaint: true,
        useCORS: true
      }).then(function(canvas) {
        loading.close();
        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(pdfTitle + ".pdf");
      });
    };
  }
};

// 在main.js中

import htmlToPdf from "./util/htmlToPdf";
Vue.use(htmlToPdf);

//在需要导入的DOM节点上设置  id="pdfDom"   直接写入点击事件@click="getPdf('此处传入导入的文件名称')"
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值