将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>
	  )
 }

使用问题

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


相关推荐
LDX前端校草6 分钟前
前端开发规则配置
前端
代码老中医9 分钟前
2026前端工程化新范式:如何用AI驱动你的设计系统?
前端
用户114818678948413 分钟前
Vite项目中的SVG雪碧图
前端·面试
这个实现不了16 分钟前
vue写一些进度条样式1
前端
小蜜蜂dry16 分钟前
可视化大屏适配方案之- px-To-viewport
前端
willow36 分钟前
Promise由浅入深
javascript·promise
董员外39 分钟前
LangChain.js 快速上手指南:Tool的使用,给大模型安上了双手
前端·javascript·后端
用泥种荷花1 小时前
【LangChain.js学习】 RAG(检索增强生成)完整实现解析
前端
willow1 小时前
Generator与Iterator
javascript
兔子零10241 小时前
Star-Office-UI-Node 实战:从 0 到 1 接入 OpenClaw 的多 Agent 看板
前端·ai编程