app.jsx

import './App.css'
import * as pdfjs from "pdfjs-dist";
import "pdfjs-dist/web/pdf_viewer.css";
import { useEffect, useRef, useState } from 'react'
import { PDFViewer, PDFLinkService, EventBus } from 'pdfjs-dist/web/pdf_viewer'; pdfjs.GlobalWorkerOptions.workerSrc = 'https://cdn.bootcdn.net/ajax/libs/pdf.js/2.11.338/pdf.worker.min.js' function App() {
useEffect(() => {
initPdfView();
}, []) // pdfView自动缩放
const autoScale = (viewer) => {
// 缩放模式: "page-fit" ,"auto" ,"page-width"
viewer.currentScaleValue = 'page-width';
} // 监听pdfView外部容器变化,主要是配合自动缩放
const onResize = (viewer) => {
const resizeObserver = new ResizeObserver(entries => { // 创建观察对象
autoScale(viewer) // entries[0].contentRect
});
resizeObserver.observe(containerRef.current); // 指定要观察的dom
} // 定义一些页面所需变量
const [viewer, setViewer] = useState({});
const [page, setPage] = useState(1);
const [pages, setPages] = useState(0);
const containerRef = useRef(null); /**
* 初始化pdfView
*/
const initPdfView = () => {
const pdfUrl = 'https://cos.dingshaohua.cn/aegis/1.pdf';
const linkService = new PDFLinkService();
const eventBus = new EventBus();
eventBus.on("pagesinit", (e) => {
onResize(e.source) // 同一次轮回 是拿不到view的,所以只能通过e.source取出
});
const newViewer = new PDFViewer({
container: containerRef.current, // 显示PDF的容器dom
linkService,
eventBus,
textLayerMode: 2,
renderer: "canvas",
});
linkService.setViewer(newViewer);
pdfjs.getDocument(pdfUrl).promise.then((pdf) => {
linkService.setDocument(pdf);
newViewer.setDocument(pdf);
setPages(pdf.numPages);
})
setViewer(newViewer)
} /**
* 下一页
*/
const onNext = () => {
if (viewer.currentPageNumber < pages) {
viewer.currentPageNumber++;
setPage(viewer.currentPageNumber)
}
} /**
* 跳转页面
*/
const onSkip = () => {
if (viewer.currentPageNumber < pages) {
viewer.currentPageNumber = page;
}
} return (
<>
<div className='skip'>
<input type="number" value={page} onChange={(e) => { setPage(Number(e.target.value)) }} />/{pages}
<div onClick={onSkip}>跳转</div> <div onClick={onNext}>下一页</div>
</div>
<div ref={containerRef} className='container'>
<div id="viewer" className="pdfViewer"></div>
</div>
</>
)
} export default App

app.css

.container{
position: absolute;
margin: auto;
left: 0;
right: 0;
width: 50%;
height: 100%;
overflow: auto;
} .skip{
background-color: aqua;
width: 180px;
position: fixed;
right: 0;
top: 0;
padding: 10px;
display: flex;
z-index: 3;
} .skip input{
width:20%;
} .skip div{
background-color: gray;
cursor: pointer;
user-select: none;
margin-left: 10px;
}

效果

pdfjs-dist v2.11.338写个react demo的更多相关文章

  1. Git for Windows v2.11.0 Release Notes

    homepage faq contribute bugs questions Git for Windows v2.11.0 Release Notes Latest update: December ...

  2. 写的cursor demo仅作记录

    declare @objectID int; declare objcur cursor for object_id from m_object open objcur fetch next from ...

  3. 如何使用npm构建一个react demo项目

    方法一: 1) 安装node.js环境  点我进入nodejs官网 1.1) 下载LTS(Long term support)版本,安装 1.2) 在cmd中使用以下命令查看node是否安装成功 no ...

  4. 最近写了一个demo,想看看java和go语言是怎么写的

    最近写了一个demo:demo的github地址 一. 简单介绍 1. Server端 它是一个WebApi服务,把它当成一个黑盒就行了. 2. MiddleServer端 是重点,它是一个WebAp ...

  5. 写一个react hook:useLoading

    在写业务的过程中,我们总是会遇到这样的需求,在请求时显示一个 loading,然后请求结束后展示数据.以一个是不是 vip 的场景为例,如果不加入 loading 状态,页面可能在未请求的时候显示非 ...

  6. python爬虫学习(11) —— 也写个AC自动机

    0. 写在前面 本文记录了一个AC自动机的诞生! 之前看过有人用C++写过AC自动机,也有用C#写的,还有一个用nodejs写的.. C# 逆袭--自制日刷千题的AC自动机攻克HDU OJ HDU 自 ...

  7. 如何写好react组件

    react 组件方面: 总结 React 组件的三种写法 及最佳实践 [涨经验] React组件编写思路(一) 使用react-router实现单页面应用时设置页面间过渡的两种方式 [翻译]基于 Cr ...

  8. [翻译]怎么写一个React组件库(二)

    本文同步发布于知乎专栏 https://zhuanlan.zhihu.com/p/27434018,喜欢本文的就去知乎点个赞支持下吧- 引言 该系列文章将通过创建一个组件库来引导你学习如何构建自己的组 ...

  9. react 脚手架 立即可以写业务 react + react-router-dom + less + axios + antd

    https://github.com/cynthiawupore/wq-cli

  10. [翻译]怎么写一个React组件库(一)

    本文同步发布于知乎专栏 https://zhuanlan.zhihu.com/p/27401329,喜欢本文的就去知乎点个赞支持下吧- 引言 该系列文章将通过创建一个组件库来引导你学习如何构建自己的组 ...

随机推荐

  1. 2021年扩展DevOps的6种方法

    2021年扩展DevOps的6种方法 加强devops流程的自动化 为了满足快速.高质量应用程序交付的需求,现代软件团队需要一种超越常规性能测试的方法.在这里,以devops为中心的方法可以提供更快. ...

  2. SpringBoot3整合SpringSecurity6(一)快速入门

    大家好,我是晓凡. 写在前面 不知道小伙伴们在学SpringSecurity过程中有没有和我一样的经历和烦恼. ①看完一篇文章或者一个教程,感觉学会了.但是一到实际项目中就不知道怎么用: ②被Spri ...

  3. kettle+report designer导出带样式的excel包含多个sheet页

    场景介绍: 运用pentaho report designer报表设计器,查询数据库字典表生成带有样式的excel,通过kettle pentaho报表输出组件导出形成数据字典,最终形成的数据字典样式 ...

  4. ThinkPHP3.2无法加载控制器

    无法加载控制器:Admin 错误位置 FILE: D:\phpStudy\WWW\wisdom\ThinkPHP\Library\Think\App.class.php LINE: 101 在将Thi ...

  5. 什么是AC自动机?如何实现?

    什么是AC自动机? 是基于 Trie树 和 KMP失配指针 的一种高效多模式匹配算法.AC自动机能够一次构建,随后在遍历文本时同时匹配多个敏感词. AC自动机算法的典型应用是敏感词匹配,在各大社交媒体 ...

  6. python 3 No module named ‘Crypto‘ 解决方案

    pip3 install pycryptodome pip3 install crypto Pip3 install pycrypto 本机(mac)环境的解决方案: pip3 uninstall p ...

  7. 9.9K star!大模型原生即时通信机器人平台,这个开源项目让AI对话更智能!

    嗨,大家好,我是小华同学,关注我们获得"最新.最全.最优质"开源项目和高效工作学习方法 "高稳定.支持插件.多模态 - 大模型原生即时通信机器人平台" 项目亮点 ...

  8. 开源的java内网穿透 - 维基代理(wiki-proxy)

    1.简介 维基代理(wiki-proxy).开源的java内网穿透项目. 技术栈:cdkjFramework(维基框架).JPA.Netty 遵循MIT许可,因此您可以对它进行复制.修改.传播并用于任 ...

  9. 【经验】微信小程序开发 云后台比价(自带云开发、leancloud、bmob)(2022/10/31更新)

    目录 前言 1. 免费配额 2. 超过额度时收费情况 3. 另外的价钱 总结 前言 作为前端开发者,没有购买云服务器的习惯,在只需要使用数据库的情况下,开发微信小程序完全可以用现在免费的云后台. 常用 ...

  10. 2025年Android面试题含答案

    今年过完年,毫无悬念,成了失业人员之一,于是各种准备面试.前后将近一个月时间,面试10几家公司,基本上80%的企业都拿到了offer.这里面基本上大部分都是小企业居多,少部分中厂,两三家大厂.我并没有 ...