时间:2021-05-26
本文实例为大家分享了Vue将页面导出成PDF文件的具体代码,供大家参考,具体内容如下
我在前端岗位上要实现个可视化图表页的PDF文件导出,在这里给大家分享下使用jsPDF和html2canvas包将Vue页面导出成PDF的方法。
1. 下载npm包
2. 创建插件.js文件
Vue-cli项目的话是在./utils文件夹下,我在这里使用的nuxt框架,所以是在./plugins文件夹下。
import html2Canvas from 'html2canvas';import JsPDF from 'jspdf';export default { install (Vue, options) { Vue.prototype.getPdf = function () { var title = this.pdfTitle; // 导出的pdf文件名 html2Canvas(document.querySelector(this.pdfSelector), { //导出的html元素 allowTaint: 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'); }) } }}上面的插件代码可以直接复制,然后在引用的Vue文件中填入自己的参数就可以了。
3. 修改引用页面
导出按钮调用getPdf方法,data填入参数。
<template> <div id="pdfPrint"> <!-- 调用getPdf方法 --> <el-button @click="getPdf('#pdfPrint')">保存为PDF</el-button> </div></template><script>export default { data() { return { // 填入导出的pdf文件名和html元素 pdfTitle: '因子评价报告', pdfSelector: '#pdfPrint', } },大概就是这样啦,非常地简单。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
使用闪电PDF编辑器如何将PDF文档中的图片如何设置成同样大小?在工作中需要将PDF文档中的图片如何设置成同样大小,使用闪电PDF编辑器可以快速的完成这一操作,
本文实例为大家分享了Vue导出页面为PDF格式的具体代码,供大家参考,具体内容如下导出为图片1.将页面html转换成图片npminstallhtml2canva
【怎么制作网站页面】如何将网站的网页设计成wap网站?dreamweaver如何制作简单的网页?下面就和小编一起来看看吧! 如何将网站的网页设计成wap网
proe怎么导出PDF文件?很多朋友在刚开始使用proe软件时,还不太清楚如何导出PDF文件,今天小编整理了关于proe导出PDF文件的操作方法,感兴趣的朋友快
cad导成pdf的方法如下: 1、打开CAD,找到你要导出的CAD图,然后左上角文件,选打印; 2、打印机那里选择PDF格式; 3、选择导出的尺寸; 4