文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue怎么将html页面生成高清晰pdf文件

2023-06-29 09:01

关注

本文小编为大家详细介绍“vue怎么将html页面生成高清晰pdf文件”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue怎么将html页面生成高清晰pdf文件”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

需要借助html2canvas和jspdf这两个插件

首先是将页面用html2canvas生成base64的图片,再用jspdf将图片插入到pdf

效果图如下

vue怎么将html页面生成高清晰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文件”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯