Vue網(wǎng)頁(yè)html轉(zhuǎn)換PDF(最低兼容ie10)的思路詳解
HTML轉(zhuǎn)PDF:
1.頁(yè)面底層實(shí)現(xiàn)——Vue:最低兼容ie10
2.實(shí)現(xiàn)思路:
1> 使用html2canvas.js將網(wǎng)頁(yè)轉(zhuǎn)換為圖片
2> 使用jsPdf.debug.js將canvas生成的圖片轉(zhuǎn)換為pdf文件
具體實(shí)現(xiàn):
要這樣實(shí)現(xiàn)首先要引入兩個(gè)插件:
html2canvas.js
jsPdf.debug.js
注:
因?yàn)閕e10在canvas截圖時(shí)候會(huì)出現(xiàn)部分樣式丟失的情況,所以在代碼中有部分修改了頁(yè)面的樣式
所以建議在做截圖的時(shí)候,將頁(yè)面代碼復(fù)制一份到隱藏域,在隱藏域里面做修改,這樣就不會(huì)修改頁(yè)面原有樣式了
如果大家有更好的方法,歡迎提議
下面上代碼:
<script type="text/ecmascript-6">
import co from 'co'
import html2Canvas from '../html2canvas'
import JsPDF from '../jsPdf.debug'
export default {
title: '用戶信息',
data () {
return {}
},
methods: {
// 核心代碼
printOut () {
// 獲取需要打印的區(qū)域,以div為單位,此處使用的是vue的選擇器
let pdfDom = document.querySelector('#pdf-wrap')
// 因?yàn)樵趇e10下,會(huì)出現(xiàn)input樣式丟失的情況,所以在此處清楚input的標(biāo)簽的邊框
let arrnode = pdfDom.querySelectorAll('input')
for (var i = 0; i < arrnode.length; i++) {
arrnode[i].style.border = 'hidden'
}
// 設(shè)置背景色
pdfDom.style.background = '#FFFFFF'
let _this = this
html2Canvas(pdfDom, {
allowTaint: true, taintTest: false,
onrendered: function (canvas) {
// 開(kāi)始canvas截圖
// 開(kāi)始準(zhǔn)備工作
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
// 此處圖片格式可以是PNG,也可是JPEG,注意:需要考慮Browser支持的圖片格式
let pageData = canvas.toDataURL('image/PNG', 1)
pdfDom.style.display = 'none'
// 開(kāi)始將圖片轉(zhuǎn)換為PDF
// 設(shè)置紙張大小,方向
let PDF = new JsPDF('', 'pt', 'a4')
if (leftHeight < pageHeight) {
PDF.addImage(pageData, 'PNG', 0, 0, imgWidth, imgHeight)
} else {
while (leftHeight > 0) {
PDF.addImage(pageData, 'PNG', 0, position, imgWidth, imgHeight)
leftHeight -= pageHeight
position -= 841.89
if (leftHeight > 0) {
PDF.addPage()
}
}
}
// 保存PDF
PDF.save(_this.userInfo.card_id + '-' + _this.userInfo.user_name + '.pdf')
}
})
html2Canvas()
}
},
ready () {
}
}
</script>
總結(jié)
以上所述是小編給大家介紹的Vue網(wǎng)頁(yè)html轉(zhuǎn)換PDF(最低兼容ie10)的思路詳解,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue實(shí)現(xiàn)簡(jiǎn)單的發(fā)表評(píng)論功能
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)簡(jiǎn)單的發(fā)表評(píng)論功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
vue+echarts動(dòng)態(tài)更新數(shù)據(jù)及數(shù)據(jù)變化重新渲染方式
這篇文章主要介紹了vue+echarts動(dòng)態(tài)更新數(shù)據(jù)及數(shù)據(jù)變化重新渲染方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
淺談VUE監(jiān)聽(tīng)窗口變化事件的問(wèn)題
下面小編就為大家分享一篇淺談VUE監(jiān)聽(tīng)窗口變化事件的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
vue如何將html內(nèi)容轉(zhuǎn)為圖片并下載到本地
這篇文章主要介紹了vue如何將html內(nèi)容轉(zhuǎn)為圖片并下載到本地,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
effect返回runner單測(cè)實(shí)現(xiàn)示例詳解
這篇文章主要為大家介紹了effect返回runner單測(cè)實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12

