VUE 网页生成 PDF
保存当前网页为PDF格式到本地一、安装依赖1. npm install --save html2canvas// 作用是html转图片2. npm install jspdf --save// 再将图片转为pdf二、设置格式函数import html2Canvas from 'html2canvas'import JsPDF from 'jspdf'export def...
·
保存当前网页为PDF格式到本地
一、安装依赖
1. npm install --save html2canvas // 作用是html转图片
2. npm install jspdf --save // 再将图片转为pdf
二、设置格式函数
import html2Canvas from 'html2canvas'
import JsPDF from 'jspdf'
export default{
install (Vue, options) {
Vue.prototype.getPdf = function (title) {
html2Canvas(document.querySelector('#pdfDom'), {
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')
}
)
}
}
}
三、main.js引入
import htmlToPdf from './htmlToPdf';
Vue.use(htmlToPdf);
四、运用
五、遇到问题
如图,在导出文件时,发现网络错误,可能是因为下载器不支持,首先换浏览器试一次,如果可以下载,则就是下载器不支持。
作者微信公众号“怪東瓜”,有问题私聊,我们共同探讨实用技术,练出最美身材。
更多推荐
已为社区贡献3条内容
所有评论(0)