前端把页面用PDF导出

使用场景:

把展示的页面内容,导出PDF方便查看

主要使用的是 jspdf-html2canvas 组件

安装

javascript 复制代码
npm install jspdf-html2canvas --save   
//^1.6.0  如果使用不行,再尝试控制版本使用
//npm install jspdf-html2canvas@1.6.0 --save

使用

javascript 复制代码
import html2PDF from 'jspdf-html2canvas';

// 绑定元素
const reportNewRef = React.useRef<HTMLDivElement>(null);

//下载函数
 const testDownload = async () => {
    try {
      const dom = reportNewRef.current;
      if (!dom) {
        return;
      }

      await html2PDF(dom, {
        jsPDF: {
          format: 'a4',
          unit: 'mm',
          orientation: 'portrait',
          hotfixes: ['px_scaling'], // 解决 px 单位在高分屏上的缩放问题
        },
        html2canvas: {
          scale: 2, // 放大比例,解决高分辨率屏幕下图像模糊问题
          useCORS: true,
          logging: false,
          backgroundColor: '#fff', // 背景颜色设置为白色
          scrollX: 0,
          scrollY: 0, // 禁止纵向滚动
          windowWidth: dom.scrollWidth, // 设置为内容的实际宽度,确保完整渲染
        },
        margin: { top: 0, right: 12, bottom: 0, left: 12 },
        imageType: 'image/jpeg', // 使用 JPEG 格式,通常比 PNG 更小
        imageQuality: 1, // 设置为 1,表示最高质量的 JPEG 图片
        output: '下载文件.pdf', // 输出文件名
      });
      message.success('PDF下载成功');
    } catch (err) {
      console.error('导出失败', err);
      message.error('PDF导出失败');
    }
};





// 点击下载按钮
<Button key="download" type="primary" icon={<DownloadOutlined />}
    onClick={() => {
         //这里触发下载函数 
         testDownload()
    }}
>
 下载PDF
</Button>


//需要下载的页面
<div ref={reportNewRef}>

这里是下载内容,里面就正常写,怎么展示在页面上就怎么写。

</div>

隐藏页面来下载

主要是利用元素控制下载页面的显隐并且把下载内容定位到用户看不到的地方。

监听是否显示和页面是否存在,延时下载,考虑数据加载需要时间,这一块也可以考虑到数据请求完成,页面加载完成后,再做下载操。

javascript 复制代码
 const [open, setOpen] = useState(false);
 const reportNewRef = React.useRef<HTMLDivElement>(null);
 const testDownload = async () => {
    try {
      const dom = reportNewRef.current;
      if (!dom) {
        return;
      }

      await html2PDF(dom, {
        jsPDF: {
          format: 'a4',
          unit: 'mm',
          orientation: 'portrait',
          hotfixes: ['px_scaling'], // 解决 px 单位在高分屏上的缩放问题
        },
        html2canvas: {
          scale: 2, // 放大比例,解决高分辨率屏幕下图像模糊问题
          useCORS: true,
          logging: false,
          backgroundColor: '#fff', // 背景颜色设置为白色
          scrollX: 0,
          scrollY: 0, // 禁止纵向滚动
          windowWidth: dom.scrollWidth, // 设置为内容的实际宽度,确保完整渲染
        },
        margin: { top: 0, right: 12, bottom: 0, left: 12 },
        imageType: 'image/jpeg', // 使用 JPEG 格式,通常比 PNG 更小
        imageQuality: 1, // 设置为 1,表示最高质量的 JPEG 图片
        output: '下载文件.pdf', // 输出文件名
      });
      message.success('PDF下载成功');
    } catch (err) {
      console.error('导出失败', err);
      message.error('PDF导出失败');
    } finally {
      setOpen(false);
    }
  };

  useEffect(() => {
  let timeoutId: NodeJS.Timeout;

  if (open === true && reportNewRef.current) {
    // 清理之前的定时器
    timeoutId = setTimeout(() => {
      testDownload();
    }, 1000);
  }

  // 清理函数
  return () => {
    if (timeoutId) {
      clearTimeout(timeoutId);
    }
  };
}, [open, reportNewRef]); // 只有最后一次触发会执行


// 点击下载按钮
<Button key="download" type="primary" icon={<DownloadOutlined />}
    onClick={() => {
         //这里触发下载函数 
       setOpen(true)
    }}
>
 下载PDF
</Button>


//下载内容  通过控制元素显隐和绝对定位使其元素位置隐藏显示元素
 {open && (
   <div className="absolute top-[-200vh] w-[1000px] z-50 bg-white">
      <div>下载内容</div>
   </div>
)}
相关推荐
豹哥学前端1 小时前
10分钟彻底搞懂 window 对象、全局环境与 JS 引擎
前端·面试
晴殇i1 小时前
前端混合状态管理架构:Redux Toolkit + Zustand 协同设计、规范落地与性能优化
前端·openai
OpenTiny社区1 小时前
GenUI SDK 生成式UI:六大开发特性详解,适配多种业务场景
前端·github·ai编程
大家的林语冰2 小时前
TS 登顶第一语言;JS 最新 Temporal 时间减屎;Node 爆发反 AI 运动;CSS 将支持图片亮暗切换《前端周刊》
前端·javascript·css
Hilaku2 小时前
OpenClaw 为什么突然不火了?
前端·javascript·程序员
asdzx672 小时前
使用 Python 读取 PDF: 提取文本和图片
开发语言·python·pdf
精益数智工坊2 小时前
物料管理是什么?物料管理的具体工作有哪些?
大数据·前端·数据库·人工智能·精益工程
岩岩很哇塞!2 小时前
【vue实现模仿探探卡片滑动切换效果】
前端·javascript·vue.js
优化控制仿真模型2 小时前
【社工】初级社会工作者历年真题及答案解析PDF电子版(2010-2025年)
经验分享·pdf