HTML5 无法原生渲染 PDF,需依赖浏览器内置查看器(如 PDFium)或 pdf.js 库;iframe 方式简单但控制弱、兼容差;pdf.js 可完全控制渲染但需处理 worker 路径、CORS、字体等配置。
HTML5 本身没有原生 PDF 渲染能力,不能直接“嵌入并渲染 PDF”——你看到的所谓“HTML5 嵌入 PDF”,实际是靠浏览器内置 PDF 查看器(如 Chrome/Edge 内置的 PDFium)或第三方 JS 库(如 pdf.js)实现的预览。
直接加载 PDF 文件最简单,但有兼容性和控制限制多数现代浏览器支持通过 显示 PDF,本质是调用浏览器自带 PDF 查看器:
pdfj
s.disabled = false)Access-Control-Allow-Origin: *(否则 iframe 白屏无报错)这是真正意义上“基于 HTML5 技术栈”的方案:纯 JS 解析 PDF 字节流,用 Canvas 渲染页面,不依赖浏览器 PDF 插件。
page-loaded、text-layer-rendered 等事件,适合做文档审核、批注系统build/ 目录(至少含 pdf.min.js 和 pdf.worker.min.js)PDFJS.disableStream = false 启用流式加载)很多“嵌入失败”其实和 PDF 本身或部署方式有关,不是代码问题:
Failed to load PDF file:检查响应头是否含 Content-Type: application/pdf;Nginx/Apache 需配置 MIME 类型,否则返回 text/plain 会导致 pdf.js 解析失败Unexpected server response:后端返回了 401/403 但没设 CORS,浏览器静默拦截;可在 PDFJS.getDocument() 前加 fetch 检查状态码PDFJS.GlobalWorkerOptions.workerSrc 后设置 PDFJS.cMapUrl = './cmaps/' 并部署对应 CMap 文件PDFJS.disableInteractiveForms = true),或改用 Viewer 模式而非手动 Canvas 渲染真正要落地,得先明确:你要的是“能点开就行”的轻量预览,还是“可集成到业务流程里”的可控组件。前者用 足够,后者必须上 pdf.js——但别直接 npm install pdfjs-dist 后就跑,worker 路径、CORS、字体、跨域 cookie 这几处漏掉一个,页面就白屏且控制台毫无提示。
来电咨询