博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
将Vue页面导出为pdf格式并进行下载
阅读量:4130 次
发布时间:2019-05-25

本文共 1686 字,大约阅读时间需要 5 分钟。

1.使用npm下载两个插件

a.将html页面转换成图片npm install --save html2canvas b.将图片生成pdfnpm install jspdf --save

2.在utils文件夹中创建一个名字叫个htmlToPdf.js的文件,内容如下:

// 导出页面为PDF格式import html2Canvas from 'html2canvas'import JsPDF from 'jspdf'export default{  install (Vue, options) {    Vue.prototype.getPdf = function () {      var title = this.htmlTitle      html2Canvas(document.querySelector('#pdfDom'), {        allowTaint: true,        useCORS: true      }).then(function (canvas) {        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(title + '.pdf')      }      )    }  }}

3. 在main.js中注册我们自定义的插件htmlToPdf.js

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

4.在按钮上直接绑定getPdf方法,即可实现导出功能

//这里面的内容是我们要导出的部分 id为"pdfDom",和上面"htmlToPdf.js"文件中的id必须一致.此部分将就是pdf显示的部分
//getPdf()是我们在main.js中绑定在Vue中的,固定名称,直接调用即可下载,无需在methods中写方法
export default {  //  data () {      return {      htmlTitle: '页面导出PDF文件名'  //这个也是固定写法,pdf文件下载的名称      }  } }

 

转载地址:http://ejuvi.baihongyu.com/

你可能感兴趣的文章
App开发:强制更新app
查看>>
Android Studio:签名并导包
查看>>
第三方SDK : Bugly:异常管理 +运营统计 + 内测分发 + 应用升级
查看>>
Android Studio :Gradle
查看>>
手机助手(一):准备阶段
查看>>
手机助手(三):自定义属性 + 飞入飞出
查看>>
手机助手(四):复杂的ListView + 自定义控件
查看>>
手机助手(五):模块化开发 + nineOldAndroid.jar
查看>>
源码或学习网站
查看>>
手机助手(二):侧拉栏drawerLayout+Tab+Viewpager+ListView+Pulltorefresh+imageloder
查看>>
Android Studio BUG
查看>>
Android基础:Date & Time组件(上)
查看>>
Android基础:Date & Time组件(下)
查看>>
第三方开源库:日期时间选择器(TimePickerDialog)+ 省市区三级联动(CityPicker) + 一级滚动
查看>>
第三方开源库:OkHttp
查看>>
科研机构分析环境搭建
查看>>
二叉堆(优先队列)
查看>>
外存IO操作
查看>>
如何开发一个程序
查看>>
python初学
查看>>