前端预览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组件 ⭐⭐ ⭐⭐⭐ ⭐⭐⭐⭐
图片化 ⭐⭐⭐ ⭐⭐
相关推荐
QQ1__8115175154 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态4 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子4 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室4 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI4 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing4 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者4 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册4 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李4 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢4 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web