前端 使用 pdf.js加载PDF文件

一、定义承载pdf的容器

html 复制代码
<template>
    <div>
        <div id="pdfContainer"></div>
    </div>
</template>

二、加载pdf

javascript 复制代码
<script lang="ts" setup>

import pdf from './components/230402643.pdf'

import { getDocument } from 'pdfjs-dist'
import * as pdfjsLib from 'pdfjs-dist/build/pdf.mjs'
import * as pdfjsWorker from 'pdfjs-dist/build/pdf.worker.mjs'

const pdfLoader = async () => {

    pdfjsLib.GlobalWorkerOptions.workerSrc = pdfjsWorker

    const container = document.getElementById('pdfContainer')

    const loadingTask = getDocument(pdf);
    loadingTask.promise.then(doc => {
        // console.log(doc)
        const numPages = doc.numPages
        totalPage.value = doc.numPages
        // console.log('Number of Pages:', numPages) // pdf页数

        let lastPromise // will be used to chain promises
        lastPromise = doc.getMetadata().then(metadata => {
            // console.log('metadata  = ', metadata)
            // console.log('Metadata is:', JSON.stringify(metadata, null, 2))
            if(metadata.metadata) {
                // console.log('All Metadata:', metadata.metadata.getAll())
            }
        })

        const loadPage = (pageNum) => {
            return doc.getPage(pageNum).then(page => {
                // console.log('# Page ' + pageNum)

                const viewport = page.getViewport({ scale: 1.0 })
                // console.log('size = ', viewport.width + 'x' + viewport.height)

                const canvas = document.createElement('canvas');
                const context = canvas.getContext('2d');
                canvas.height = viewport.height;
                canvas.width = viewport.width;
                container.appendChild(canvas);
                page.render({ canvasContext: context, viewport})

                return page.getTextContent().then(content => {
                    const strings = content.items.map(item => {
                        // console.log('content item:', item)
                        return (item as any).str
                    })
                    // console.log('## Text Content:', strings.join(' '))
                    page.cleanup()
                })
            })
        }

        for(let i = 1; i <= numPages; i++) {
            lastPromise = lastPromise.then(loadPage.bind(null, i))
        }
        return lastPromise
    }).catch(err => {
        // console.log('err = ', err)
    })
}
</script>

说明:上述方法是将pdf全文全部加载完成,会存在加载慢的情况。

相关推荐
nvd1113 分钟前
企业级 LLM 实战:在受限环境中基于 Copilot API 构建 ReAct MCP Agent
前端·copilot
Dragon Wu22 分钟前
TailWindCss cva+cn管理样式
前端·css
烤麻辣烫27 分钟前
Web开发概述
前端·javascript·css·vue.js·html
Front思38 分钟前
Vue3仿美团实现骑手路线规划
开发语言·前端·javascript
徐同保40 分钟前
Nano Banana AI 绘画创作前端代码(使用claude code编写)
前端
Ulyanov41 分钟前
PyVista与Tkinter桌面级3D可视化应用实战
开发语言·前端·python·3d·信息可视化·tkinter·gui开发
计算机程序设计小李同学41 分钟前
基于Web和Android的漫画阅读平台
java·前端·vue.js·spring boot·后端·uniapp
干前端43 分钟前
Message组件和Vue3 进阶:手动挂载组件与 Diff 算法深度解析
javascript·vue.js·算法
lkbhua莱克瓦2444 分钟前
HTML与CSS核心概念详解
前端·笔记·html·javaweb
沛沛老爹1 小时前
从Web到AI:Agent Skills CI/CD流水线集成实战指南
java·前端·人工智能·ci/cd·架构·llama·rag