将PDF流使用 canvas 绘制展示在页面上(一)

将PDF流展示在页面上

使用 pdfjs-dist 库来渲染 PDF 页面到 canvas 上进行绘制展示

安装 pdfjs-dist 依赖

bash 复制代码
npm install pdfjs-dist
或者
yarn add pdfjs-dist

创建一个组件来处理 PDF 流的加载和渲染

该组件中是一个包含 PDF 文件的 Base64。

将 pdf 流传入该组件中使用

javascript 复制代码
/** @format */

import React, { useState, useEffect, useRef } from 'react';
var pdfjsLib = require('pdfjs-dist/es5/build/pdf.js');
// eslint-disable-next-line import/first
import 'pdfjs-dist/es5/build/pdf.worker.entry';

const PdfViewer = ({ url, id }) => {
    const [pageNumbers, setPageNumbers] = useState(0);
    const [currentPage, setCurrentPage] = useState(1);
    const [loading, setLoading] = useState(true);
    const [rendering, setRendering] = useState(false);
    const pdfRef = useRef(null);
    function renderPdf(pdfFile) {
        let canvas = document.getElementById(id);
        let canvasContext = canvas.getContext('2d');
        pdfFile.getPage(currentPage).then((page) => {
            //逐页解析PDF
            var viewport = page.getViewport({ scale: 5 }); // 页面缩放比例,值越大越清晰
            canvas.height = viewport.height;
            canvas.width = viewport.width;
            canvasContext.clearRect(0, 0, canvas.width, canvas.height);
            var renderContext = {
                canvasContext: canvasContext,
                viewport: viewport,
                rotate: 90,
            };
            setRendering(true);
            page.render(renderContext).promise.finally(() => {
                setRendering(false);
            }); //渲染生成
        });
    }

    useEffect(() => {
        let loadingTask = pdfjsLib.getDocument({
            url: url,
            //cMapUrl: './cmaps/',
            //cMapPacked: true,
        });
        loadingTask.promise
            .then((pdf) => {
                // console.log(pdf.numPages);
                pdfRef.current = pdf;
                setPageNumbers(pdf.numPages);
                renderPdf(pdf);
            })
            .catch((error) => {
                console.log(error);
            })
            .finally(() => {
                setLoading(false);
            });
    }, []);

    useEffect(() => {
        if (pdfRef.current) {
            window.scrollTo({ top: 0 });
            renderPdf(pdfRef.current);
        }
    }, [currentPage]);

    return (
        <div>
            <canvas id={'pdf' + id} style={{ width: '100%' }} />
        </div>
    );
};

export default PdfViewer;

使用示例

javascript 复制代码
import React from 'react';
import PdfViewerfrom './PdfViewer.jsx';
 render() {
 const url= 'XXXX....BYFhEdCmVuZHN0cmVhbQplbmRvYmoKc3RhcnR4cmVmCjg2NTkxCiUlRU9GCg=='// base64 格式
	  return (
		  	<PdfViewer 
		  		id={'pdf_file'} 
		  		url={`data:application/pdf;base64,${url}`}
		  	></PdfViewer>
	  )
 }

使用问题

在使用的过程中,有一个项目是可以的,但是另一个项目会报错,如下图:


相关推荐
风度前端13 小时前
npm 2026安全新规下的免登录发包策略
前端
冴羽14 小时前
2026 年前端必须掌握的 4 个 CSS 新特性!
前端·javascript·css
rgeshfgreh14 小时前
Python流程控制:从条件到循环实战
前端·数据库·python
狗头大军之江苏分军14 小时前
告别旧生态:Ant Design 6 不再支持 IE 与现代前端趋势解读
前端·javascript·后端
C_心欲无痕14 小时前
nginx - 开启 gzip 压缩
运维·前端·nginx
闲云一鹤14 小时前
2026 最新 ComfyUI 教程 - 本地部署 AI 生图模型 - Z-Image-Turbo
前端·人工智能·ai编程
开开心心_Every14 小时前
安卓后台录像APP:息屏录存片段,行车用
java·服务器·前端·学习·eclipse·edge·powerpoint
狗头大军之江苏分军14 小时前
Ant Design 6.0 正式发布:从 V5 到 V6 有哪些变化?
前端
Highcharts.js14 小时前
Highcharts Grid 表格/网格安装 |官方安装文档说明
开发语言·javascript·表格组件·highcharts·官方文档·安装说明·网格组件
优弧14 小时前
Claude 终于对普通人下手了!Cowork 发布,你的最强 AI 打工搭子来了!
前端·后端