您的位置:首页 > 新闻 > 资讯 > Vue3中生成本地pdf并下载

Vue3中生成本地pdf并下载

2025/5/24 0:31:40 来源:https://blog.csdn.net/weixin_62328265/article/details/140242342  浏览:    关键词:Vue3中生成本地pdf并下载

1. 前言

前端中经常会遇到在系统中根据数据导出一个pdf文件出来,一般都是后端来实现的,既然后端可以实现,前端为什么就不行呢,正好有一次也写了这个需求,就写了个小demo

示例图:
前端视图源码
下载完成后的的pdf文件

2. 实现步骤

  1. 首先下载html2pdf.js这个库
    yarn add html2pdf.js
    // 或
    npm i html2pdf.js
    
  2. 在项目中需要使用此功能的地方引用此组件
  3. 使用html2pdf.js
    // 获取一个dom对象,这个dom对象就是pdf中显示的内容
    let element = document.querySelector('.tableBox');// 设置html2pdf的配置
    let opt = {margin: 0, // 设置PDF页面的边距为0,即没有边距filename: `成绩表.pdf`, // 指定生成文件的名称image: { type: 'jpeg', quality: 1 }, // 设置生成PDF时使用的图像格式为JPEG,质量为1(最高质量)// 这是一个用于将HTML元素转换为canvas的库html2canvas: {scale: 2, //  缩放比例为2,即生成的canvas尺寸是原始尺寸的两倍allowTaint: false, // 设置为false,表示不允许加载跨域的图片useCORS: true, // 设置为true,允许跨域加载的图片使用CORS策略},//  控制PDF页面的分页行为// mode: 设置为avoid-all,尽量避免分页// after: 在生成PDF时,当遇到id为levelAnalysis的元素后进行分页pagebreak: { mode: 'avoid-all', after: '#levelAnalysis' },enableLinks: true, // 支持文本中放链接,可点击跳转
    };// 执行pdf的导出
    // html2pdf()将html转换为pdf
    // set(opt)表示转换为pdf时使用指定的配置
    // form表示html2pdf中将指定的dom元素加入pdf
    // save()表示将创建完成的pdf保存到本地
    html2pdf().set(opt).from(element).save();
    

3. 总结

Vue3中生成本地pdf并下载主要使用了html2pdf.js第三方库,通过此库,可以将指定的dom通过canvas转换为一张图片,这样pdf中只需要加载这个图片即可,然后通过指定的配置与指定的API即可将pdf保存到本地

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com