vue+jspdf+html2canvas导出PDF文件

摘要:
没有废话。首先,查看最终打印结果。我说最后打印的pdf文件看起来像这样。pdf文件的分页是通过设置jspdf实现的,但我暂时无法对文件内容进行分页。因为我们首先将需要打印的元素转换为画布,然后将画布转换为图像,然后将图像转换为pdf文件。
    今天开始实现日结单这个功能,日结单是允许打印的,所以我们需要将日结单以PDF的形式导出,我做的是Vue单页应用,于是查找了一番Vue如何导出PDF,看了几篇博客,实现了PDF的导出。
 
  不废话了,先看一下最终的打印结果
 
  vue+jspdf+html2canvas导出PDF文件第1张

  我丑话说在前面,最终打印出来的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>

    

免责声明:文章转载自《vue+jspdf+html2canvas导出PDF文件》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇docker run hangs问题排查记录JS获取当前时间下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

js-定时器

知识 要用定时器,先清除定时器   1、 定时器   setInterval() 循环定时器;周而复始的执行(循环执行)  setTimeout()( 执行事件,间隔时间(单位毫秒)) <script> var num=0; setInterval(function(){ console.log( num);...

java生成pdf字体的坑

java生成pdf字体的坑 做过java生成pdf的应该都知道有很多坑,特别是字体。 这里就记录一下字体的问题。 系统必须安装字体,项目的resources目录放置了要用到的中文字体,宋体和黑体。并在代码中进行了引用。但是实际发现系统仍然需要安装字体。 安装字体的坑 这里主要记录一下安装字体的坑 网上找到的教程 cd /usr/share/fonts/...

nginx配置静态路径

原因:文件资料上传至ftp上,由于需要大量图片回显,导致服务器压力过大,反应不过来,所以改为通过nginx做静态资源代理。 服务器路径为:/var/ftp/2020/10/09/12a1b8f973fc4d51b67e9a168fcb757f1602227927258.jpg 初次尝试,是通过: location /ftp/ {      root /va...

javascript ES6 新特性之 Promise,ES7 async / await

es6 一经推出,Promise 就一直被大家所关注。那么,为什么 Promise 会被大家这样关注呢?答案很简单,Promise 优化了回调函数的用法,让原本需要纵向一层一层嵌套的回调函数实现了横向的调用,也就是链式调用。 我们先来看下面的代码: 1 function getData(){ 2 setTimeout(()=>{ 3...

前端js几种加密/解密方法

一、base64加密 base64的github地址 示例 <html> <head> <title>前端的base64使用方法</title> </head> <body> </body> <script>...

Lighttpd 搭建 Web 服务器

背景:      公司项目用到了lighttpd,由于自己没有接触过,所以做下记录。 简介:      Lighttpd 是一个德国人领导的开源Web服务器软件,其根本的目的是提供一个专门针对高性能网站,安全、快速、兼容性好并且灵活的web server环境。具有非常低的内存开销,cpu占用率低,效能好,以及丰富的模块等特点。支持FastCGI, CGI,...