前端预览pdf有哪些方案

一、浏览器原生预览(最简单)

直接使用浏览器内置 PDF viewer。

方式1:iframe / embed / object

html 复制代码
<iframe src="/files/demo.pdf" width="100%" height="800px"></iframe>

html 复制代码
<embed src="/files/demo.pdf" type="application/pdf" width="100%" height="800px">

html 复制代码
<object data="/files/demo.pdf" type="application/pdf" width="100%" height="800px"></object>

优点

  • 实现极其简单
  • 不需要任何库
  • 浏览器自带缩放、下载、打印

缺点

  • UI无法定制
  • 不同浏览器体验不同
  • 移动端兼容性差

适用场景

  • 后台管理系统
  • 简单预览

二、Blob URL 预览(接口返回二进制)

如果 后端返回 PDF 二进制,可以这样处理:

javascript 复制代码
async function previewPdf() {
  const res = await fetch("/api/file/pdf");

  const blob = await res.blob();

  const url = URL.createObjectURL(blob);

  window.open(url);
}

javascript 复制代码
iframe.src = URL.createObjectURL(blob);

流程:

复制代码
后端返回 PDF binary
        ↓
fetch / axios
        ↓
new Blob()
        ↓
URL.createObjectURL()
        ↓
iframe / window.open

优点

  • 适合 权限控制下载
  • 可以 鉴权接口

缺点

  • 仍然是浏览器 viewer

三、PDF.js(最主流方案)

最专业、最常见方案。


Mozilla

开发的 PDF 渲染库。


安装

bash 复制代码
npm install pdfjs-dist

示例

javascript 复制代码
import * as pdfjsLib from "pdfjs-dist";

const loadingTask = pdfjsLib.getDocument("/demo.pdf");

loadingTask.promise.then(function(pdf) {

  pdf.getPage(1).then(function(page) {

    const scale = 1.5;

    const viewport = page.getViewport({ scale });

    const canvas = document.getElementById("canvas");

    const context = canvas.getContext("2d");

    canvas.height = viewport.height;
    canvas.width = viewport.width;

    page.render({
      canvasContext: context,
      viewport: viewport
    });

  });

});

HTML

html 复制代码
<canvas id="canvas"></canvas>

优点

功能非常强:

  • 页面分页
  • 缩放
  • 搜索
  • 高亮
  • 注释
  • 文本层
  • 自定义 UI

缺点

  • 代码复杂
  • 需要自己实现 UI

四、PDF.js Viewer(官方完整 viewer)

PDF.js 自带完整 viewer:

复制代码
web/viewer.html

使用方式:

复制代码
/viewer.html?file=/demo.pdf

示例:

html 复制代码
<iframe src="/pdfjs/web/viewer.html?file=/demo.pdf"></iframe>

优点

完整功能:

  • 搜索
  • 目录
  • 缩放
  • 打印
  • 下载
  • 页码

缺点

  • UI较重
  • 不太容易深度定制

五、Vue / React 组件库

如果你用 Vue / React,可以用封装好的组件。


Vue

Vue PDF

bash 复制代码
npm install vue-pdf

示例

vue 复制代码
<pdf src="/demo.pdf"></pdf>

常用库:

特点
vue-pdf 简单
vue3-pdfjs Vue3
pdfvuer 支持分页

React

常用:

复制代码
react-pdf

安装

bash 复制代码
npm install react-pdf

示例

jsx 复制代码
<Document file="/demo.pdf">
  <Page pageNumber={1} />
</Document>

六、在线 Office / 文档预览服务

适合 企业网盘 / 文档系统

例如:

  • OnlyOffice
  • Collabora
  • PDFTron
  • PSPDFKit

其中:

  • OnlyOffice
  • Collabora Online

都支持:

  • PDF
  • Word
  • Excel
  • PPT

优点

  • 专业文档系统
  • 支持编辑

缺点

  • 部署复杂
  • 资源占用高

七、图片化预览(特殊方案)

将 PDF 转图片:

复制代码
PDF
 ↓
Image (PNG / JPG)
 ↓
前端展示

后端常用工具:

  • Ghostscript
  • ImageMagick

优点

  • 防下载
  • 兼容性好

缺点

  • 失去文本层
  • 不可搜索

八、方案对比(工程选型)

方案 难度 功能 推荐指数
iframe ⭐⭐⭐
Blob ⭐⭐ ⭐⭐⭐
PDF.js ⭐⭐⭐⭐ ⭐⭐⭐⭐ ⭐⭐⭐⭐⭐
PDF.js viewer ⭐⭐ ⭐⭐⭐⭐ ⭐⭐⭐⭐
Vue/React组件 ⭐⭐ ⭐⭐⭐ ⭐⭐⭐⭐
图片化 ⭐⭐⭐ ⭐⭐
相关推荐
OpenTiny社区1 小时前
不仅是修复 Bug:TinyVue 3.29.0 把“无障碍信息”写进了组件的 DNA 里
前端·javascript·vue.js
鹿鹿鹿鹿isNotDefined1 小时前
Pixelium Design 更新:首版表格上线,完善表单、导航、反馈及视觉组件
前端·javascript
Pu_Nine_91 小时前
企业级 Axios 配置实战:从基础到完整封装
前端·ajax·axios·网络请求·企业级
低调小一1 小时前
OpenClaw 模型配置与火山 Coding Plan 支持清单(实践笔记)
java·前端·笔记·openclaw
毛骗导演1 小时前
万字解析 OpenClaw 源码架构-消息渠道集成简介
前端·架构
kyriewen1 小时前
别再直接 git push 了!这个"魔法"参数让你的代码质量翻倍
前端·git·命令行
1024小神1 小时前
uniapp中用vue3自己写一个验证码输入框,自动获取焦点和自动切到下一个焦点
前端
www_stdio1 小时前
手搓一个 Mini React:从 JSX 到虚拟 DOM 的完整实现
前端·react.js·面试
weixin_395448911 小时前
main.c_raw_0311_lyp
前端·网络·算法
毛骗导演1 小时前
万字解析 OpenClaw 源码架构-插件开发指南
前端·架构