本文共 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/