用JS實現HTML轉PDF


遇到這個需求,現把實現代碼整理出來,方便大家參考

<!-- html轉PDF -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/html2canvas/0.4.1/html2canvas.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.0.272/jspdf.debug.js"></script>

/*

  代碼無需改動,直接拿去套用即可

  particulars-container 為頁面最外圍盒子ID,可以從內容區開始,也可以從body范圍開始,可以根據具體情況變動

  在本地HTML轉PDF時頁面中的圖片是無法正常顯示的,需要起服務,把項目放進去

*/

html2canvas(document.getElementById('particulars-container'), {
      onrendered: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('content.pdf');
    }
})

 

 

參考文章:https://github.com/linwalker/render-html-to-pdf


免責聲明!

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



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