vue將html頁面生成高清晰pdf文件的方法
需要借助html2canvas和jspdf這兩個插件
首先是將頁面用html2canvas生成base64的圖片,再用jspdf將圖片插入到pdf
效果圖如下

createImage(){//生成圖片->pdf
let _this = this;
//----此處是解決頁面帶滾動條的時候截圖不全問題
window.pageYoffset = 0;
document.documentElement.scrollTop = 0;
document.body.scrollTop = 0;'
//----------------------------------------
let canvas = document.createElement("canvas");
let context = canvas.getContext("2d");
let _articleHtml = document.getElementById('imageTofile');
let _w = _articleHtml.clientWidth;
let _h = _articleHtml.clientHeight;
//-----這里解決生成的pdf不清晰的問題 先放大3倍----后面再縮小3倍
let scale = 3;
canvas.width = _w * scale;
canvas.height = _h * scale;
context.scale(scale, scale);
let opts = {
scale: 1,
width: _w,
height: _h,
canvas: canvas,
useCORS: true
};
(window.html2canvas || html2canvas)(_articleHtml, opts).then(canvas => {//IOS13.4無效解決 和{(intermediate value)(intermediate value)} is not a function+;
_this.createPdfAll(canvas, scale);
});
},我這里直接將整個的img插入到pdf,并未截斷分頁,因為截斷的話需要調(diào)整,不太友好,不然會把文字從中間位置截斷
createPdfAll (canvas, scale) {//生成圖片->pdf
//-----------寬高縮小3倍---------------------
let contentWidth = canvas.width / scale
let contentHeight = canvas.height / scale
//--------------------
let pdf = new jsPDF('', 'pt', [contentWidth, contentHeight+50]) //此處加50是pdf最后離底部的空白距離。根據(jù)需要自行調(diào)節(jié)
let pageData = canvas.toDataURL('image/jpeg', 1.0);
//這里只生成了一頁的pdf,并未截斷,需要截斷的話在此處操作
pdf.addImage(pageData, 'JPEG', 0, 0, contentWidth, contentHeight)
//這里是將pdf的流文件---》file文件
let filename = 'question.pdf' ;
let datauri = pdf.output('dataurlstring');
let file = this.dataURLtoFile(datauri,filename);
// 以文件的形式上傳給服務器
this.uploadImg(file)
},流文件轉(zhuǎn)成file
dataURLtoFile(dataurl, filename) {
var arr = dataurl.split(',');
var mime = arr[0].match(/:(.*?);/)[1];
var bstr = atob(arr[1]);
var n = bstr.length;
var u8arr = new Uint8Array(n);
while(n--){undefined
u8arr[n] = bstr.charCodeAt(n);
}
//轉(zhuǎn)換成file對象
return new File([u8arr], filename, {type:mime});
//轉(zhuǎn)換成成blob對象
//return new Blob([u8arr],{type:mime});
},種方案純前端實現(xiàn),無需后端配合,并且頁面還原度比較高,對于pdf操作要求不高的需求,還是比較合適的解決方案。
缺點就是無法復制,對pdf操作不大兼容
總結(jié)
到此這篇關(guān)于vue將html頁面生成高清晰pdf文件的文章就介紹到這了,更多相關(guān)vue將html頁面生成pdf文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解使用VUE搭建后臺管理系統(tǒng)(vue-cli更新至3.0)
這篇文章主要介紹了詳解使用VUE搭建后臺管理系統(tǒng)(vue-cli更新至3.0),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
vue實現(xiàn)tab切換的3種方式及切換保持數(shù)據(jù)狀態(tài)
這篇文章主要給大家介紹了關(guān)于vue實現(xiàn)tab切換的3種方式及切換保持數(shù)據(jù)狀態(tài)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-05-05
vue-next/runtime-core 源碼閱讀指南詳解
這篇文章主要介紹了vue-next/runtime-core 源碼閱讀指南詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10
vue監(jiān)聽頁面中的某個div的滾動事件并判斷滾動的位置
本文主要介紹了vue監(jiān)聽頁面中的某個div的滾動事件并判斷滾動的位置,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
vue?watch中如何獲取this.$refs.xxx節(jié)點
這篇文章主要介紹了vue?watch中獲取this.$refs.xxx節(jié)點的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08

