前端预览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组件 ⭐⭐ ⭐⭐⭐ ⭐⭐⭐⭐
图片化 ⭐⭐⭐ ⭐⭐
相关推荐
尘中客4 小时前
放弃 Echarts?前端直接渲染后端高精度 SVG 矢量图流的踩坑记录
前端·javascript·echarts·前端开发·svg矢量图·echarts避坑
FreeBuf_4 小时前
Chrome 0Day漏洞遭野外利用
前端·chrome
小彭努力中4 小时前
199.Vue3 + OpenLayers 实现:点击 / 拖动地图播放音频
前端·vue.js·音视频·openlayers·animate
2501_916007475 小时前
网站爬虫原理,基于浏览器点击行为还原可接口请求
前端·javascript·爬虫·ios·小程序·uni-app·iphone
前端大波5 小时前
Sentry 每日错误巡检自动化:设计思路与上手实战
前端·自动化·sentry
Highcharts.js6 小时前
适合报表系统的可视化图表|Highcharts支持直接导出PNG和PDF
javascript·数据库·react.js·pdf
ZC跨境爬虫6 小时前
使用Claude Code开发校园交友平台前端UI全记录(含架构、坑点、登录逻辑及算法)
前端·ui·架构
慧一居士6 小时前
Vue项目中,何时使用布局、子组件嵌套、插槽 对应的使用场景,和完整的使用示例
前端·vue.js
Можно6 小时前
uni.request 和 axios 的区别?前端请求库全面对比
前端·uni-app
M ? A7 小时前
解决 VuReact 中 ESLint 规则冲突的完整指南
前端·react.js·前端框架