前端处理导出PDF。Vue导出pdf

前言:该篇主要是解决一些简单的页面内容导出为PDF

1.安装依赖

使用到两个依赖,项目目录下运行这两个

javascript 复制代码
//页面转换成图片
npm install --save html2canvas 
//图片转换成pdf
npm install jspdf --save 

2.创建通用工具类exportPdf.js文件

可以保存在工具类目录下;

javascript 复制代码
// 导出页面为PDF格式
import html2Canvas from 'html2canvas'
import JsPDF from 'jspdf'

export function getPdf(title, id) {
  // 参数校验
  if (!title || !id) {
    console.error('Title and ID are required.')
    return
  }

  const element = document.querySelector(`#${id}`)
  if (!element) {
    console.error(`Element with ID "${id}" not found.`)
    return
  }

  html2Canvas(element, {
    allowTaint: true,
    useCORS: true,
    scale: 2
  }).then(function (canvas) {
    const contentWidth = canvas.width
    const contentHeight = canvas.height

    // A4纸尺寸 (单位: pt)
    const a4Width = 595.28
    const a4Height = 841.89

    // 设置外边距 (单位: pt)
    const marginLeft = 20
    const marginTop = 20
    const marginRight = 20
    const marginBottom = 20

    // 计算可用内容区域
    const availableWidth = a4Width - marginLeft - marginRight
    const availableHeight = a4Height - marginTop - marginBottom

    // 计算缩放比例,使内容宽度适配可用区域
    const scale = availableWidth / contentWidth

    // 按比例计算图像在页面上的尺寸
    const imgWidth = contentWidth * scale
    const imgHeight = contentHeight * scale

    // 计算每页可容纳的高度(考虑上下边距)
    const pageHeight = availableHeight
    let leftHeight = imgHeight
    let position = 0

    const pageData = canvas.toDataURL('image/jpeg', 0.95)
    const PDF = new JsPDF('', 'pt', 'a4')

    if (leftHeight < pageHeight) {
      // 内容高度小于页面可用高度,直接添加图片(带外边距)
      PDF.addImage(pageData, 'JPEG', marginLeft, marginTop, imgWidth, imgHeight)
    } else {
      // 内容高度大于页面可用高度,分页处理
      while (leftHeight > 0) {
        // 添加当前页面图像(带外边距)
        PDF.addImage(pageData, 'JPEG', marginLeft, marginTop + position, imgWidth, imgHeight)
        leftHeight -= pageHeight
        position -= a4Height

        // 如果还有剩余内容,添加新页面
        if (leftHeight > 0) {
          PDF.addPage()
        }
      }
    }

    PDF.save(title + '.pdf')
  }).catch(function (error) {
    console.error('PDF导出失败:', error)
  })
}

3.Demo例子

javascript 复制代码
<template>
    <div>
        <!-- 容器 -->
        <div id="pdfHtml" ref="printHtml">
            <h1>这是一个Demo。</h1>
        </div>
        <button @click="exportPDF">PDF导出</button>
    </div>
</template>
<script>
import { getPdf } from '@/utils/exportPdf';
export default {
    methods: {
        // 导出pdf
        exportPDF() {
            getPdf('关键因素', 'pdfHtml');
        }
    }
}
</script>
相关推荐
爱学习的程序媛2 分钟前
【Web前端】优化Core Web Vitals提升用户体验
前端·ui·web·ux·用户体验
zabr3 分钟前
花了 100+ 篇笔记,我整理出 了一套 AI Agent 工程完全指南
前端·后端·agent
软弹15 分钟前
深入理解 React Ref 机制:useRef 与 forwardRef 的协作原理
前端·javascript·react.js
YaHuiLiang19 分钟前
Ai Coding浪潮下的前端:“AI在左,裁员在右”
前端
雪碧聊技术27 分钟前
前端vue代码架子搭建
前端·javascript·vue.js·前端项目代码框架搭建
爱学习的程序媛27 分钟前
【Web前端】前端用户体验优化全攻略
前端·ui·交互·web·ux·用户体验
han_30 分钟前
JavaScript设计模式(二):策略模式实现与应用
前端·javascript·设计模式
x***r15134 分钟前
Notepad++ 8.6 安装教程:详细步骤+自定义安装路径(附注意事项)
linux·前端·javascript
Hilaku37 分钟前
为什么很多工作 5 年的前端,身价反而卡住了?🤷‍♂️
前端·javascript·面试
ai超级个体37 分钟前
前端下午茶:这 3 个网页特效建议收藏(送源码)
前端·three.js·threejs·网页设计·vibe coding·网页灵感·网页分享