首页 > 其他分享 >react批量生成pdf

react批量生成pdf

时间:2023-07-21 18:11:35浏览次数:47  
标签:const 批量 avoid 元素 react pdf css html2pdf

使用htmlpdf.js批量将html页面转为pdf,打包成zip下载。htmlpdf.js是结合html2canvasjsPDF实现的。

首先先安装包

npm install --save html2pdf.js

基本页面

import html2pdf from "html2pdf.js";
function App() {
    const handleExportPdf = () => {
        // 导出pdf
    }
    const generatePdfHtml = () => {
        return new Array(100).fill({}).map((item, index) => (
            <div style={{ paddingBottom: "10px" }}>
                这是第{index}句话,
                {`这是第${index}句话`.repeat(index)}
            </div>
        ));
    };
    return (
        <div className="App">
            <button onClick={handleExportPdf}>导出</button>
            <div style={{ position: "absolute", top: "-100000px" }}>
                // 要转为pdf的页面
                <div id="pdf1">{generatePdfHtml()}</div>
                <div id="pdf2">{generatePdfHtml()}</div>
                <div id="pdf3">{generatePdfHtml()}</div>
            </div>
        </div>
    );
}

这里需要注意的是,要转为pdf的元素不能设置position,否则导出的pdf是空白的。所以这里把定位设置到它的父元素上。

我们先来实现单个pdf的导出,如果没有额外的配置要求,可以采用基本用法

const handleExportPdf = () => {
    var element = document.getElementById('pdf1');
    html2pdf(element);
}

如果需要进行额外的配置,则如下:

const handleExportPdf = () => {
    var element = document.getElementById('pdf1');
    const opt = {
        margin: 0, 
        filename: "file.pdf",
        pagebreak: {mode: ['avoid-all', 'css', 'legacy']},
        image: { type: "jpeg", quality: 1 },
        enableLinks: true,
        html2canvas: { scale: 2, useCORS: true, allowTaint: false},
        jsPDF: { },
    };
    html2pdf(element, opt);
}

各参数含义如下:

  • margin:默认是0,pdf的页边距,它采用的是jsPDF的单位("pt" (points), "mm" , "cm", "in",默认是"mm"),值可以是数字或[vMargin, hMargin][top, left, bottom, right]
  • filename:默认是file.pdf,导出pdf的文件名。
  • pagebreak:控制pdf的分页行为,参数如下:
    • mode:默认是["css", "legacy"],值为字符串或者数组,有以下几种模式:
      • avoid-all:自动添加分页符,以避免将任何元素分割到多个页面。
      • css:根据CSSbreak-beforebreak-afterbreak-inside属性添加分页符。
      • legacy:在使用html2pdf__page-break类的元素后面添加分页符,这个属性即将被废弃。
    • before:默认为空数组,值为字符或数组,通过css选择器来判断在哪些元素前面添加分页符,比如id选择器、类选择器、标签选择器获取*来选择所有的元素。
    • after:默认为空数组,值为字符或数组,通过css选择器来判断在哪些元素后面添加分页符,与before类似。
    • avoid:默认为空数组,值为字符或数组,通过css选择器来避免在哪些元素上面添加分页符,与before类似。
      // 避免在所有的元素上添加分页符,在 #page2el 元素前添加分页符
      html2pdf().set({
          pagebreak: { mode: 'avoid-all', before: '#page2el' }
      });
      
      // 支持所有模式,不指定元素
      html2pdf().set({
          pagebreak: { mode: ['avoid-all', 'css', 'legacy'] }
      });
      
      // 采用默认模式,指定具体元素
      html2pdf().set({
          pagebreak: { before: '.beforeClass', after: ['#after1', '#after2'], avoid: 'img' }
      });
      
  • image:默认值为{type: 'jpeg', quality: 0.95},生成pdf的图片的配置,有以下两个属性:
    • type:图片类型,HTMLCanvasElement仅支持pngjpegwebp(仅chrome支持)
    • quality:图片质量,值为0-1,仅对jpegwebp生效。
  • enableLinks:默认为true,如果启用,PDF 超链接将自动添加到所有锚标记之上。
  • html2canvas:scale用来设置导出图片的缩放比例,可控制清晰度。useCORS这个属性可以用来启用或禁用对CORS的支持,allowTaint这个属性允许启用或禁用对跨域图像的支持,不开启这两个属性的话,非本地图片不能显示。全部配置可见html2canvas
  • jsPDF:配置可见jsPDF

接下来来实现打包逻辑,先安装我们需要使用的插件

npm install jszip file-saver --save

打包代码如下:

const handleExportPdf = () => {
    const workerList = [];
    const zip = new JSZip();
    const opt = {
      margin: 0, 
      filename: "file.pdf",
      pagebreak: {mode: ['avoid-all', 'css', 'legacy']},
      image: { type: "jpeg", quality: 1 },
      enableLinks: true,
      html2canvas: { scale: 2, useCORS: true, allowTaint: false},
      jsPDF: { },
    };

    for (let i = 0; i < 3; i++) {
      const element = document.getElementById(`pdf${i + 1}`);
      workerList.push(html2pdf().set(opt).from(element).outputPdf("blob"));
    }
    
    Promise.all([...workerList]).then((res) => {
      res.map((v, i) => {
        zip.file(`pdf${i + 1}.pdf`, v, { binary: true });
      });
      zip
        .generateAsync({ type: "blob" })
        .then((content) => {
          FileSaver.saveAs(content, "pdfzip");
        })
        .catch((e) => {
          console.log(e, "压缩失败");
        });
    })
};

标签:const,批量,avoid,元素,react,pdf,css,html2pdf
From: https://www.cnblogs.com/summerstar/p/17567499.html

相关文章

  • mysql 存储过程大批量插入速度慢
    MySQL存储过程大批量插入速度慢的原因及解决方法在使用MySQL数据库进行大批量数据插入时,可能会遇到插入速度慢的问题。这个问题很常见,通常是由于存储过程执行效率低下导致的。本文将介绍这个问题的原因,并提供一些优化的解决方法。原因分析在MySQL数据库中,存储过程是一组预定义的......
  • 一个简单好用的PDF目录制作器-备份
    QuickOutlineGitHub连接知乎链接......
  • vue3中组合式 API_为 reactive() 标注类型
    reactive() 也会隐式地从它的参数中推导类型<template><h3>{{book.title}}</h3><h3>{{book.author}}</h3></template><scriptsetuplang="ts">import{reactive}from"vue"constbook=reactive({title......
  • 【专题】2023年中国工业机器人行业研究报告PDF合集分享(附原数据表)
    报告链接:https://tecdat.cn/?p=33224本报告合集将基于中国工业产业升级和智能制造的背景,通过对供应端市场和产业链的分析,结合投资视角,探讨工业机器人企业如何增强自身竞争力,推动中国工业产业发展,为企业带来新的增长和转型机会,并从而思考中国工业机器人行业的现状和未来趋势。点......
  • 【专题】中国工业机器人市场研究报告PDF合集分享(附原数据表)
    报告链接:https://tecdat.cn/?p=33224本报告合集将基于中国工业产业升级和智能制造的背景,通过对供应端市场和产业链的分析,结合投资视角,探讨工业机器人企业如何增强自身竞争力,推动中国工业产业发展,为企业带来新的增长和转型机会,并从而思考中国工业机器人行业的现状和未来趋势。点......
  • 【专题】中国工业机器人市场白皮书报告PDF合集分享(附原数据表)
    报告链接:https://tecdat.cn/?p=33224本报告合集将基于中国工业产业升级和智能制造的背景,通过对供应端市场和产业链的分析,结合投资视角,探讨工业机器人企业如何增强自身竞争力,推动中国工业产业发展,为企业带来新的增长和转型机会,并从而思考中国工业机器人行业的现状和未来趋势。点......
  • 【专题】中国工业机器人行业研究报告PDF合集分享(附原数据表)
    报告链接:https://tecdat.cn/?p=33224本报告合集将基于中国工业产业升级和智能制造的背景,通过对供应端市场和产业链的分析,结合投资视角,探讨工业机器人企业如何增强自身竞争力,推动中国工业产业发展,为企业带来新的增长和转型机会,并从而思考中国工业机器人行业的现状和未来趋势。点......
  • 批量新增接口正确传参以及优化(含数组传参)
    需求页面: 接口文档说明: 单个新增计划传参: 批量新增计划传参:批量新增7月24日和8月1日的复制计划 接口优化:由于当前医生给指定的患者新增计划时,当前医生和患者都不会发生变化,批量新增时仅是新增多个计划时间,所以计划时间可以调整为数组进行传参接口文档优化: 单个计......
  • 探索Reactor网络模型在当今应用领域的革新
    本文分享自华为云社区《驾驭网络技术的未来:探索Reactor网络模型在当今应用领域的革新》,作者:LionLong。本文介绍了Linux网络设计中的Reactor网络模型及其在实际应用中的重要性。Reactor模型是一种经典的事件驱动设计模式,广泛应用于构建高性能、可扩展的网络服务器。我们将探讨R......
  • 电子书下载 免费pdf Python编程从入门到实践 第2版
    电子书下载-Python编程从入门到实践第2版简介Python是一种简单易学的编程语言,广泛应用于数据分析、人工智能、Web开发等领域。《Python编程从入门到实践》是一本非常受欢迎的Python入门教程。本文将介绍如何下载免费的PDF版本的第2版《Python编程从入门到实践》电子书,并提供一......