vue怎么将html页面生成高清晰pdf文件
发表于:2025-02-05 作者:千家信息网编辑
千家信息网最后更新 2025年02月05日,本文小编为大家详细介绍"vue怎么将html页面生成高清晰pdf文件",内容详细,步骤清晰,细节处理妥当,希望这篇"vue怎么将html页面生成高清晰pdf文件"文章能帮助大家解决疑惑,下面跟着小编的
千家信息网最后更新 2025年02月05日vue怎么将html页面生成高清晰pdf文件
本文小编为大家详细介绍"vue怎么将html页面生成高清晰pdf文件",内容详细,步骤清晰,细节处理妥当,希望这篇"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,并未截断分页,因为截断的话需要调整,不太友好,不然会把文字从中间位置截断
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最后离底部的空白距离。根据需要自行调节 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) },
流文件转成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); } //转换成file对象 return new File([u8arr], filename, {type:mime}); //转换成成blob对象 //return new Blob([u8arr],{type:mime}); },
种方案纯前端实现,无需后端配合,并且页面还原度比较高,对于pdf操作要求不高的需求,还是比较合适的解决方案。
缺点就是无法复制,对pdf操作不大兼容
读到这里,这篇"vue怎么将html页面生成高清晰pdf文件"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。
生成
文件
页面
图片
高清
高清晰
文章
内容
对象
方案
问题
合适
妥当
不大
两个
从中
位置
前端
就是
底部
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
服务器硬盘组成虚拟硬盘
云服务器的安全防护
宁波奥克斯软件开发
ssh 服务器
泉州网络安全实战培训
夏冰软件开发
网络服务器维修多少钱
山西专业软件开发价格优惠
java学生成绩数据库
遵义软件开发招标
惠州旅游软件开发收费
超融合网络安全产品有哪些
初级数据库运维的工作内容
帝国神话自建服务器总崩溃
软件开发中职学校哪家好
中国奥运网络安全日
游戏引擎服务器端口要怎么打开
如何守牢网络安全阵地
游戏数据库后缀名
服务器ddr3内存32g性能低
静安区互联网络技术服务流程
山西多米网络技术有限公司
是以信息网络技术为
搭建flv服务器
贵阳dell服务器总代理
网络安全正常运行的保障是
海外服务器租借
苏州沉户赢网络技术有限公司
软件开发保密协议通用
商友数据库连接失败