zoukankan      html  css  js  c++  java
  • 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>

        

  • 相关阅读:
    f(n)=1-1/2+1/3-1/4...+1/n
    练习2-15 求简单交错序列前N项和 (15 分)
    练习2-14 求奇数分之一序列前N项和 (15 分)
    练习2-13 求N分之一序列前N项和 (15 分)
    练习2-12 输出华氏-摄氏温度转换表 (15 分)
    【转载】如何从零开始开发一款嵌入式产品(20年的嵌入式经验分享学习,来自STM32神舟系列开发板设计师的总结
    【转载-Andrew_qian】stm32中断学习
    【转-Andrew_qian】stm32中断嵌套全攻略
    【转】写给自学者的入门指南
    【转】作为一个程序员,数学对你到底有多重要
  • 原文地址:https://www.cnblogs.com/N1ckeyQu/p/11382195.html
Copyright © 2011-2022 走看看