前端实现多个PDF文件合并为一个PDF文件

最近遇到一个功能: 即将多个文件服务器中的PDF文件合并为一个PDF文件进行下载打印操作。

话不多说开搞

思路

我们需要使用到pdf-lib这个库,它提供了一组丰富的功能,可以在客户端和服务器端中对PDF文件进行各种操作.

首先需要安装这个库

js 复制代码
npm i pdf-lib
  1. 创建一个空白PDF文档。
  2. 遍历即将合并的PDF文档,获取二进制数据。
  3. 依次将数据写入到空白文档中。(如果单个PDF中有多页,需要一次一页往新建空白PDF中添加)
  4. 将合并后的PDF文档保存Blob对象
  5. 创建下载链接并且触发下载

实操

好的,根据上面的思路我们开始实现这个功能。

js 复制代码
import React from "react";
import { PDFDocument } from "pdf-lib";
export default function Test() {
  async function mergePDFs(pdfUrls) {
    // 创建一个新的空白PDF文档
    const mergedPdfDoc = await PDFDocument.create();

    for (const pdfUrl of pdfUrls) {
        // 获取PDF文件的二进制数据
        const pdfBytes = await fetch(pdfUrl).then(response => response.arrayBuffer());

        // 将获取到的PDF文件添加到新的文档中
        const pdfDoc = await PDFDocument.load(pdfBytes);
        // 如果单个PDF为多页,则要一页一页往新建的PDF中添加
        const copiedPages = await mergedPdfDoc.copyPages(pdfDoc, pdfDoc.getPageIndices());
        copiedPages.forEach(page => mergedPdfDoc.addPage(page));
    }

    // 将合并后的PDF保存为Blob对象
    const mergedPdfBytes = await mergedPdfDoc.save();
    const mergedPdfBlob = new Blob([mergedPdfBytes], { type: 'application/pdf' });

    // 创建下载链接
    const downloadLink = document.createElement('a');
    downloadLink.href = URL.createObjectURL(mergedPdfBlob);
    // 设置下载文件名
    downloadLink.download = 'mergedPdf.pdf'; 

    // 触发下载
    downloadLink.click();
}
// mergePDFs()的入参为文件服务器中的PDF文件链接,需要手动替换
  return (
    <div>
      <button
        onClick={() =>
          mergePDFs([
            "https://test/01.pdf",
            "https://test/02.pdf",
            "https://test/03.pdf",
          ])
        }
      >
        下载
      </button>
    </div>
  );
}

实际效果

下面是简单效果展示

相关推荐
一只大侠的侠7 分钟前
React Native for OpenHarmony:日期选择功能完整实现指南
javascript·react native·react.js
Zhencode7 分钟前
vue3运行时核心模块之runtime-dom
前端·javascript·vue.js
一只大侠的侠11 分钟前
React Native实战:高性能StickyHeader粘性标题组件实现
javascript·react native·react.js
夏幻灵12 分钟前
CSS 布局深究:行框模型、幽灵节点与绝对居中的数学原理
前端·css
打瞌睡的朱尤21 分钟前
Vue day13~16Vue特性,Pinia,大事件项目
前端·javascript·vue.js
We་ct24 分钟前
LeetCode 61. 旋转链表:题解+思路拆解
前端·算法·leetcode·链表·typescript
风象南29 分钟前
用 ASCII 草图 + AI 快速生成前端代码
前端
_OP_CHEN36 分钟前
【前端开发之JavaScript】(三)JS基础语法中篇:运算符 / 条件 / 循环 / 数组一网打尽
开发语言·前端·javascript·网页开发·图形化界面·语法基础·gui开发
zheshiyangyang41 分钟前
前端面试基础知识整理【Day-5】
前端·面试·职场和发展
岱宗夫up9 小时前
FastAPI入门(上篇):快速构建高性能Python Web API
开发语言·前端·python·fastapi