vue如何使用html2canvas和JsPDF導(dǎo)出pdf組件
更新時(shí)間:2024年09月13日 10:05:33 作者:侯六六
這篇文章主要介紹了vue如何使用html2canvas和JsPDF導(dǎo)出pdf組件問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
使用html2canvas和JsPDF導(dǎo)出pdf組件
來看實(shí)例
<template> <div class="g-down-pdf"> <div ref="pdfDom"> //插入的內(nèi)容 <slot name="content" ></slot> </div> <div @click="savePdf" class="get-pdf"> <slot name="button"> <div>下載PDF</div> </slot> </div> </div> </template>
<script> import html2canvas from 'html2canvas' import JsPDF from 'jspdf' export default { components: { }, props: { }, data() { return { } }, methods: { savePdf() { const title = '評(píng)估報(bào)告' // 滾動(dòng)條會(huì)導(dǎo)致空白 導(dǎo)出時(shí)需置頂 window.pageYOffset = 0 document.documentElement.scrollTop = 0 document.body.scrollTop = 0 // 在ios手機(jī)上會(huì)導(dǎo)致 上方空白 后邊內(nèi)容丟失 在電腦瀏覽器上的ios并不會(huì) const u = navigator.userAgent const isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1 // android終端 const isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/) // ios終端 html2canvas(this.$refs.pdfDom, { allowTaint: true, y: isIOS ? 200 : 0 }) html2canvas(this.$refs.pdfDom, {allowTaint: true,y: isIOS ? 200 : 0}) .then((canvas) => { const contentWidth = canvas.width const contentHeight = canvas.height const pageHeight = contentWidth / 592.28 * 841.89 let leftHeight = contentHeight let position = 0 const imgWidth = 595.28 const imgHeight = 592.28 / contentWidth * contentHeight const pageData = canvas.toDataURL('image/jpeg', 1.0) const PDF = new JsPDF('', 'pt', 'a4') // 有兩個(gè)高度需要區(qū)分,一個(gè)是html頁面的實(shí)際高度,和生成pdf的頁面高度(841.89) // 當(dāng)內(nèi)容未超過pdf一頁顯示的范圍,無需分頁 if (leftHeight < pageHeight) { PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight) } else { // 分頁 while (leftHeight > 0) { // 在pdf.addImage(pageData, 'JPEG', 左,上,寬度,高度)設(shè)置在pdf中顯示; PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight) leftHeight -= pageHeight position -= 841.89 if (leftHeight > 0) { PDF.addPage() } } } PDF.save(title + '.pdf') }) } } } </script>
<style scoped lang="less"> .get-pdf{ width: 100vw; height: 160px; background: #FFFFFF; box-shadow: 0px 2px 0px 0px #F5F5F5; display: flex; align-items: center; justify-content: center; margin-top: 40px; /*position: fixed;*/ /*bottom: 0;*/ &>div{ width: 90vw; height: 100px; background: #4475D6; border-radius: 8px; text-align: center; line-height: 100px; font-size: 36px; font-weight: 500; color: #FFFFFF; } } </style>
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue結(jié)合ElementUI上傳Base64編碼后的圖片實(shí)例
這篇文章主要介紹了Vue結(jié)合ElementUI上傳Base64編碼后的圖片實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04vue下history模式刷新后404錯(cuò)誤解決方法
這篇文章主要介紹了vue下history模式刷新后404錯(cuò)誤解決方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08vue-cli實(shí)現(xiàn)多頁面多路由的示例代碼
本篇文章主要介紹了vue-cli實(shí)現(xiàn)多頁面多路由的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-01-01axios中post請(qǐng)求json和application/x-www-form-urlencoded詳解
Axios是專注于網(wǎng)絡(luò)數(shù)據(jù)請(qǐng)求的庫,相比于原生的XMLHttpRequest對(duì)象,axios簡單易用,下面這篇文章主要給大家介紹了關(guān)于axios中post請(qǐng)求json和application/x-www-form-urlencoded的相關(guān)資料,需要的朋友可以參考下2022-10-10elementUI中el-upload文件上傳的實(shí)現(xiàn)方法
ElementUI的組件支持多種事件鉤子,如http-request、before-upload和on-change,以實(shí)現(xiàn)自定義文件上傳處理,這篇文章主要介紹了elementUI中el-upload文件上傳的實(shí)現(xiàn)方法,需要的朋友可以參考下2024-11-11