前端通过 jspdf 和 html2canvas 工具将网页生成 pdf

由于 html2canvas 的性能问题,该方案对于页数比较多的场景生成的非常慢,可以试着使用 modern-screenshot 工具看是否性能会得到提升。

javascript 复制代码
import html2canvas from 'html2canvas'
import { jsPDF } from 'jspdf'

async function exportPdf(){
  const pages = document.querySelectorAll('.report-page')
  if (!pages.length) return
  const doc = new jsPDF({
    orientation: pageConfig.pageDirection as // 页面方向
      | 'p'
      | 'portrait'
      | 'l'
      | 'landscape'
      | undefined,
    format: pageConfig.pageSize, // 页面大小,例如 'A4'
    unit: 'mm',
  })
  for (const [i, page] of pages.entries()) {
    curPage.value = i + 1 // 当前页码
    if (i !== 0) {
      doc.addPage(
        pageConfig.pageSize,
        pageConfig.pageDirection as
          | 'p'
          | 'portrait'
          | 'l'
          | 'landscape'
          | undefined,
      )
    }
    page.style.border = 'none'
    const canvas = await html2canvas(page, {
      scale: 5,
    })
    const isNormalPage = pageConfig.value.pageDirection === 'p'
    doc.addImage({
      imageData: canvas.toDataURL('image/jpeg'),
      format: 'JPEG',
      x: 0,
      y: 0,
      width: isNormalPage
        ? pageConfig.pageWidth
        : pageConfig.pageHeight,
      height: isNormalPage
        ? pageConfig.pageHeight
        : pageConfig.pageWidth,
    })
  }
  const rawdata = doc.output('datauristring')
  window.pdfData = rawdata
  doc.save(`${pageConfig.name || '预览'}.pdf`)
}

执行完 doc.save 后会自动触发浏览器下载。

相关推荐
梦幻通灵20 分钟前
Vue3 Element日期控件置灰明天之后日期
前端·javascript·vue.js
晓131340 分钟前
【Cocos Creator 3.x】篇——第一章 简介
前端·javascript·游戏引擎
ZC跨境爬虫1 小时前
跟着 MDN 学JavaScript day_10:数组——数据的有序集合
android·java·开发语言·前端·javascript
晓13131 小时前
【Cocos Creator 2.x】篇——第五章 游戏常用关键技术
前端·javascript·vue.js·游戏引擎
qq4356947012 小时前
Vue03
javascript·vue.js
樱花的浪漫2 小时前
Typescript、Zod基础
前端·javascript·人工智能·语言模型·自然语言处理·typescript
竹林8182 小时前
监听智能合约事件,我用 wagmi v2 踩了三天坑,终于找到了稳定方案
前端·javascript
用户852495071842 小时前
Bun 到底是什么?一个比 Node.js "更快更香"的 JS 运行时
javascript·程序员
riuphan2 小时前
JavaScript 事件循环:单线程异步编程的核心机制
前端·javascript