vue+jspdf+html2canvas導出PDF文件


    今天開始實現日結單這個功能,日結單是允許打印的,所以我們需要將日結單以PDF的形式導出,我做的是Vue單頁應用,於是查找了一番Vue如何導出PDF,看了幾篇博客,實現了PDF的導出。
 
  不廢話了,先看一下最終的打印結果
 
  

 

  我丑話說在前面,最終打印出來的pdf文件就是這個樣子,通過對jspdf的設置實現了pdf文件的分頁,但文件的內容我暫時沒有能力進行分頁。因為我們是先將我們需要進行打印的元素(比如id="pdfDom"的div)轉換成canvas,canvas轉換成圖片,再將圖片放入pdf文件中。如果我們需要對內容進行分頁,那我們就要獲取div中全部元素的高度,然后進行判斷等一系列操作.......

 

  太麻煩了,這個日結單的內容肯定是動態的,而且無法保證里面有多少個元素,所以到了這一步我就放棄了,如果哪位同好有解決方案,歡迎在評論區給我留言。

 

    一、首先添加兩個模塊:
    
cnpm install html2canvas --save cnpm install jspdf --save

    二、定義全局函數..創建一個htmlToPdf.js文件在指定位置,比如你可以放在('@/components/utils/htmlToPdf'),該文件內容如下

 

// 導出頁面為PDF格式
import html2Canvas from 'html2canvas' import JsPDF from 'jspdf' export default { install(Vue, options) { Vue.prototype.getPdf = function(title) { var element = document.querySelector('#pdfDom'); // 這個dom元素是要導出pdf的div容器
      setTimeout(() => { html2Canvas(element).then(function(canvas) { var contentWidth = canvas.width; var contentHeight = canvas.height; //一頁pdf顯示html頁面生成的canvas高度;
          var pageHeight = contentWidth / 592.28 * 841.89; //未生成pdf的html頁面高度
          var leftHeight = contentHeight; //頁面偏移
          var position = 0; //a4紙的尺寸[595.28,841.89],html頁面生成的canvas在pdf中圖片的寬高
          var imgWidth = 595.28; var imgHeight = 592.28 / contentWidth * contentHeight; var pageData = canvas.toDataURL('image/jpeg', 1.0); var pdf = new JsPDF('', 'pt', 'a4'); //有兩個高度需要區分,一個是html頁面的實際高度,和生成pdf的頁面高度(841.89)
          //當內容未超過pdf一頁顯示的范圍,無需分頁
          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'); }); }, 0); } } }

    三、在main.js文件中引用我們定義的全局函數

import htmlToPdf from '@/components/utils/htmlToPdf' Vue.use(htmlToPdf)

    四、在組件中使用即可

<template>
  <div>
    <div id="pdfDom">
      需要生成pdf的內容
    </div>


    <el-button type="danger" @click="toGetPdf">導出PDF</el-button>
  </div>
</template>


<script> export default { data() { return { title: '' } }, methods: { 

    toGetPdf() {
      /* 這行代碼很重要,它讓頁面的滾動條跳到了最上方
      如果點擊打印按鈕的時候,滾動條沒有在最上方,打印內容會是不完整的
      當然,用起來體驗也會差一點,如果你有更好的辦法,
      歡迎來評論區,我們一起探討*/
      window.scrollTo(0, 0);
      this.getPdf(this.title);
    }

 } } </script>


<style>
</style>

    

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM