前端 使用 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全文全部加载完成,会存在加载慢的情况。

相关推荐
疯狂的沙粒5 分钟前
在uni-app中如何从Options API迁移到Composition API?
javascript·vue.js·uni-app
行云流水剑9 分钟前
【学习记录】如何使用 Python 提取 PDF 文件中的内容
python·学习·pdf
siwangqishiq210 分钟前
Vulkan Tutorial 教程翻译(四) 绘制三角形 2.2 呈现
前端
李三岁_foucsli11 分钟前
js中消息队列和事件循环到底是怎么个事,宏任务和微任务还存在吗?
前端·chrome
尽欢i11 分钟前
HTML5 拖放 API
前端·html
IDRSolutions_CN21 分钟前
PDF 转 HTML5 —— HTML5 填充图形不支持 Even-Odd 奇偶规则?(第二部分)
java·经验分享·pdf·软件工程·团队开发
xiaominlaopodaren25 分钟前
Three.js 光影魔法:如何单独点亮你的3D模型
javascript
PasserbyX27 分钟前
一句话解释JS链式调用
前端·javascript
1024小神28 分钟前
tauri项目,如何在rust端读取电脑环境变量
前端·javascript
Nano33 分钟前
前端适配方案深度解析:从响应式到自适应设计
前端