当前位置: 首页 > news >正文

PDF.js介绍以及使用

一、PDF.js是什么

PDF.js是一个JavaScript库,可以在现代Web浏览器中渲染和显示PDF文件。它的主要作用是将PDF文件转换为HTML5格式,以便在浏览器上进行展示和交互。

PDF.js的主要功能包括:

  1. 在浏览器中显示PDF:PDF.js使用HTML5的canvas元素来呈现PDF页面,使得用户可以在浏览器中直接查看PDF文件,而无需依赖外部的PDF阅读器插件。
  2. 支持基本的浏览功能:PDF.js提供了一套用户界面,包括缩放、滚动、翻页等浏览功能,使用户能够方便地导航和浏览PDF文件。
  3. 支持文本搜索:PDF.js可以对PDF文件进行文本搜索,用户可以输入关键字来查找并定位到相应的内容。
  4. 支持页面导航:PDF.js提供了页面导航功能,用户可以跳转到特定的页面,或者在查看多页PDF时进行翻页。
  5. 支持缩放和旋转:PDF.js允许用户调整PDF页面的缩放级别,并可以旋转页面以适应不同的阅读需求。
  6. 支持批注和标记:PDF.js可以让用户在PDF文件中进行批注和标记,例如划线、画框、添加注释等,以便在阅读或共享时进行交流和标记重点。

总的来说,PDF.js提供了一种在Web浏览器中展示和操作PDF文件的解决方案,使用户能够直接在浏览器中浏览和使用PDF,而无需依赖外部的PDF阅读器插件或专门的PDF编辑工具。

二、PDF.js使用

官网
https://mozilla.github.io/pdf.js/
简单显示案例

<!DOCTYPE html>
<html>
<head><title>PDF.js Example</title><style>#pdf-container {width: 800px;height: 600px;}</style>
</head>
<body>
<div id="pdf-container"></div><script src="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/2.11.338/pdf.js"></script>
<script>// 指定工作线程脚本的路径pdfjsLib.GlobalWorkerOptions.workerSrc = 'https://cdnjs.cloudflare.com/ajax/libs/pdf.js/2.11.338/pdf.worker.js';// 获取容器元素var container = document.getElementById('pdf-container');// 加载PDF文档pdfjsLib.getDocument('./2.pdf').promise.then(function(pdf) {// 获取第一页pdf.getPage(1).then(function(page) {var scale = 1.5;var viewport = page.getViewport({ scale: scale });// 创建一个<canvas>元素用于显示PDF页面var canvas = document.createElement('canvas');var context = canvas.getContext('2d');canvas.width = viewport.width;canvas.height = viewport.height;// 将PDF页面渲染到<canvas>元素中page.render({canvasContext: context,viewport: viewport});// 将<canvas>元素添加到容器中container.appendChild(canvas);});});
</script>
</body>
</html>

这段代码是使用PDF.js库在浏览器中显示PDF文件的示例。如果你想要修改代码以实现一些功能,可以参考以下示例修改:

  1. 添加翻页功能:
var currentPage = 1;
function renderPage(pageNumber) {container.innerHTML = ''; // 清空容器pdf.getPage(pageNumber).then(function(page) {var scale = 1.5;var viewport = page.getViewport({ scale: scale });var canvas = document.createElement('canvas');var context = canvas.getContext('2d');canvas.width = viewport.width;canvas.height = viewport.height;page.render({canvasContext: context,viewport: viewport});container.appendChild(canvas);currentPage = pageNumber;});
}// 监听翻页按钮点击事件
document.getElementById('prev-btn').addEventListener('click', function() {if (currentPage > 1) {renderPage(currentPage - 1);}
});document.getElementById('next-btn').addEventListener('click', function() {if (currentPage < pdf.numPages) {renderPage(currentPage + 1);}
});

在HTML中添加两个按钮:

<button id="prev-btn">Previous</button>
<button id="next-btn">Next</button>

这样就可以通过点击按钮来翻页了。

  1. 文本搜索功能:
function search(text) {var searchParams = {query: text,highlightAll: true};pdf.getPage(currentPage).then(function(page) {return page.getTextContent();}).then(function(textContent) {pdfjsLib.renderTextLayer({textContent: textContent,container: container,viewport: page.getViewport({ scale: scale }),textDivs: []}, searchParams);});
}// 监听搜索表单提交事件
document.getElementById('search-form').addEventListener('submit', function(event) {event.preventDefault();var searchText = document.getElementById('search-input').value;search(searchText);
});

在HTML中添加搜索表单:

<form id="search-form"><input id="search-input" type="text" placeholder="Search"><button type="submit">Search</button>
</form>

这样就可以在表单中输入关键字进行文本搜索了。

请注意,以上只是示例代码,实际实现中可能需要根据具体需求进行调整和完善。同时,需要确保PDF.js和相关依赖的正确引入,以及正确指定PDF文件的路径和文件名。

相关文章:

PDF.js介绍以及使用

一、PDF.js是什么 PDF.js是一个JavaScript库&#xff0c;可以在现代Web浏览器中渲染和显示PDF文件。它的主要作用是将PDF文件转换为HTML5格式&#xff0c;以便在浏览器上进行展示和交互。 PDF.js的主要功能包括&#xff1a; 在浏览器中显示PDF&#xff1a;PDF.js使用HTML5的…...

经常使用的排序算法

一、直接插入排序 #include <stdio.h>void insert_sort(int arr[], int n){int i, j, tmp;for (i 1; i < n; i){tmp arr[i];j i - 1;while (j > 0 && arr[j] > tmp){ // 将要插入的元素与数组中的元素比较&#xff08;从后向前比&#xff09;arr[j …...

msyql 24day 数据库主从 主从复制 读写分离 master slave 有数据如何增加

目录 环境介绍读写分离纵向扩展横向扩展 数据库主从准备环境主库环境(master)从库配置(slave)状态分析重新配置问题分析 报错解决从库验证 有数据的情况下 去做主从清理环境环境准备数据库中的锁的机制主库配置从库配置最后给主库解锁常见错误 环境介绍 将一个数据库的数据 复…...

使用 Taro 开发鸿蒙原生应用 —— 探秘适配鸿蒙 ArkTS 的工作原理

背景 在上一篇文章中&#xff0c;我们已经了解到华为即将发布的鸿蒙操作系统纯血版本——鸿蒙 Next&#xff0c;以及各个互联网厂商开展鸿蒙应用开发的消息。其中&#xff0c;Taro作为一个重要的前端开发框架&#xff0c;也积极适配鸿蒙的新一代语言框架 —— ArkTS。 本文将…...

Linux下 自定义多线程并发快速压缩解压缩脚本

文章目录 自定义多线程压缩解压缩脚本使用 Linux下 自定义多线程并发快速压缩解压缩脚本 Linux下常用的tar工具无法支持并行 压缩和解压&#xff0c;对于大量小文件的解压缩&#xff0c;可借助pigz工具实现多线程并行工作&#xff0c;实现更为高效的压缩和解压缩。 自定义多线…...

ubuntu20.04下安装pcl_ubuntu安装pcl

pcl点云数据库&#xff0c;用来进行3D信息的获取与处理&#xff0c;和opencv相比较&#xff0c;opencv是用来处理二维信息&#xff0c;他是学术界与工业界针对点云最全的库&#xff0c;且网络上相关的资料很多。以下是pcl的安装步骤以及遇到的问题。 提前说明&#xff0c;本人…...

阿里云常用配置:日志采集、OSS、RAM 权限策略

文章目录 引言I 日志采集1.1 具体查询语法1.2 查询示例1.3 设置token时间(登录过期时间)II OSS2.1 设置防盗链2.2 验证Referer防盗链是否生效III 通义灵码 (智能编码)IV RAM 权限策略4.1 短信策略4.2 内容风险检测引言 SLS I 日志采集...

回顾丨2023 SpeechHome 第三届语音技术研讨会

下面是整体会议的内容回顾&#xff1a; 18日线上直播回顾 18日上午9:30&#xff0c;AISHELL & SpeechHome CEO卜辉宣布研讨会开始&#xff0c;并简要介绍本次研讨会的筹备情况以及报告内容。随后&#xff0c;CCF语音对话与听觉专委会副主任、清华大学教授郑方&#xff0c…...

【flink】状态清理策略(TTL)

flink的keyed state是有有效期(TTL)的&#xff0c;使用和说明在官网描述的篇幅也比较多&#xff0c;对于三种清理策略没有进行横向对比得很清晰。 全量快照清理(FULL_STATE_SCAN_SNAPSHOT)增量清理(INCREMENTAL_CLEANUP)rocksdb压缩清理(ROCKSDB_COMPACTION_FILTER) 注意&…...

4. 行为模式 - 中介者模式

亦称&#xff1a; 调解人、控制器、Intermediary、Controller、Mediator 意图 中介者模式是一种行为设计模式&#xff0c; 能让你减少对象之间混乱无序的依赖关系。 该模式会限制对象之间的直接交互&#xff0c; 迫使它们通过一个中介者对象进行合作。 问题 假如你有一个创建…...

2015年第四届数学建模国际赛小美赛A题飞机上的细长座椅解题全过程文档及程序

2015年第四届数学建模国际赛小美赛 A题 飞机上的细长座椅 原题再现&#xff1a; 航空公司座位是指在旅途中乘客可以乘坐的座位。一些航空公司现在推出了新的经济舱“超薄”座位。这些座椅除了重量较轻外&#xff0c;理论上还允许航空公司在不显著影响乘客舒适度的情况下增加运…...

机器学习笔记(二)使用paddlepaddle,再探波士顿房价预测

目标 用paddlepaddle来重写之前那个手写的梯度下降方案&#xff0c;简化内容 流程 实际上就做了几个事&#xff1a; 数据准备&#xff1a;将一个批次的数据先转换成nparray格式&#xff0c;再转换成Tensor格式前向计算&#xff1a;将一个批次的样本数据灌入网络中&#xff…...

【Linux】权限篇(二)

权限目录 1. 前言2. 权限2.1 修改权限2.2 有无权限的对比2.3 另外一个修改权限的方法2.3.1 更改用户角色2.3.2 修改文件权限属性 3. 第一个属性列4. 目录权限5. 默认权限 1. 前言 在之前的一篇博客中分享了关于权限的一些知识&#xff0c;这次紧接上次的进行&#xff0c;有需要…...

reduce累加器的应用

有如下json数据&#xff0c;需要统计Status的值为0和1的数量 const data {"code": "001","results": [{"Status": "0",},{"Status": "0",},{"Status": "1",}] }方法一:用reduce方…...

助力硬件测试工程师之EMC项目测试。

1&#xff1a;更新该系列的目的 接下来的一个月内&#xff0c;将更新硬件测试工程师的其中测试项目--EMC项目&#xff0c;后续将会出安规等项目&#xff0c;助力测试工程师的学习。 2&#xff1a;如何高效率的展现项目的基础以及一些细节知识点 通过思维导图以及标准的规定进行…...

Github 2023-12-23 开源项目日报 Top10

根据Github Trendings的统计&#xff0c;今日(2023-12-23统计)共有10个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Python项目6C项目2C项目1Jupyter Notebook项目1HTML项目1Go项目1非开发语言项目1 免费API集体清单 创建周期…...

Quartz.net 正则表达式触发器

1、创建项目 项目类型控制台应用程序&#xff0c;.Net Framework框架版本 4.7.2 2、引入框架 NuGet\Install-Package Quartz -Version 3.8.0 3、创建Job 自定义Job实现接口IJob&#xff0c;在Execute方法实现定时逻辑&#xff0c; using Quartz; using System; using Sys…...

【已解决】修改了网站的class样式name值,会影响SEO,搜索引擎抓取网站及排名吗?

问题&#xff1a; 修改了网站的class样式name值&#xff0c;会影响搜索引擎抓取网站及排名吗&#xff1f; 解答&#xff1a; 如果你仅仅修改了网站class样式的名称&#xff0c;而没有改变网站的结构和内容&#xff0c;那么搜索引擎通常不会因此而影响它对网站的抓取和排名。但…...

微信小程序开发系列-02注册小程序

上一篇文章&#xff0c;创建了一个最小的小程序&#xff0c;但是&#xff0c;还有3个疑问没有弄清楚&#xff0c;还是基于demo1工程&#xff0c;这篇文章继续探索。 当前的目录结构是否是完备的呢&#xff1f;&#xff08;虽然小程序可以运行起来&#xff09;app.js文件内容还…...

安装 PyCharm 2021.1 保姆级教程

作者&#xff1a;billy 版权声明&#xff1a;著作权归作者所有&#xff0c;商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处 前言 目前能下载到的最新版本是 PyCharm 2021.1。 请注意对应 Python 的版本&#xff1a; Python 2: 2.7Python 3: >3.6, <3.11…...

STM32F103C8T6驱动MAX30102:从I2C配置到心率可视化,一个LED灯带你看懂心跳

STM32F103C8T6驱动MAX30102&#xff1a;从I2C配置到心跳可视化实战指南 当LED灯随着你的心跳闪烁时&#xff0c;冰冷的电子元件仿佛被赋予了生命。本文将带你深入探索如何用STM32F103C8T6驱动MAX30102血氧传感器&#xff0c;将生物信号转化为直观的视觉反馈。不同于简单的数据采…...

别再死记硬背!一张图+三个口诀,快速理解自反、对称、传递闭包怎么求

离散数学闭包运算&#xff1a;图解口诀实战&#xff0c;3分钟掌握核心技巧 第一次接触离散数学中的闭包运算时&#xff0c;很多同学都会被各种定义和符号绕晕。其实只要掌握几个简单的视觉化技巧&#xff0c;就能像搭积木一样轻松构建自反、对称和传递闭包。本文将用最直观的关…...

从零开始:用MC1648和AD835搭建一个63MHz调幅无线发射器(附完整电路图)

从零开始&#xff1a;用MC1648和AD835搭建63MHz调幅无线发射器实战指南 在电子工程领域&#xff0c;高频电路设计一直被视为"皇冠上的明珠"&#xff0c;而调幅无线发射器则是其中最具代表性的项目之一。本文将带你从零开始&#xff0c;用MC1648压控振荡器和AD835乘法…...

终极指南:4步让旧Mac运行最新macOS的完整教程

终极指南&#xff1a;4步让旧Mac运行最新macOS的完整教程 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 还在为你的老Mac无法升级最新系统而烦恼吗&#xff…...

LizzieYzy:围棋AI分析的终极免费工具,5分钟快速上手

LizzieYzy&#xff1a;围棋AI分析的终极免费工具&#xff0c;5分钟快速上手 【免费下载链接】lizzieyzy LizzieYzy - GUI for Game of Go 项目地址: https://gitcode.com/gh_mirrors/li/lizzieyzy 围棋AI分析、免费围棋助手、LizzieYzy快速入门、围棋复盘工具、AI棋力提…...

【独家拆解】Sora 2正式版底层架构升级:从DiT-XL到时空联合注意力v3.2,性能提升217%的关键证据

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Sora 2正式版发布背景与核心定位 OpenAI 于2024年第三季度正式发布 Sora 2&#xff0c;标志着视频生成模型从实验性原型迈入工业级部署新阶段。此次发布并非简单迭代&#xff0c;而是基于对数百万小时真…...

DeepSeek Coder真能替代初级程序员?实测37个真实开发任务后的性能拐点分析

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;DeepSeek Coder真能替代初级程序员&#xff1f;实测37个真实开发任务后的性能拐点分析 我们对 DeepSeek Coder v2.5 在 GitHub 公共仓库中抽取的 37 个真实开发场景&#xff08;含 LeetCode 中等题、小…...

AI赋能数字钱包:构建安全智能的DeFi资产管理助手

1. 项目概述&#xff1a;当AI遇上数字钱包&#xff0c;一场关于信任与效率的变革最近在关注Web3和数字资产管理领域的朋友&#xff0c;可能都注意到了“windagency/valora.ai”这个项目。乍一看&#xff0c;它像是一个托管在GitHub上的开源代码库&#xff0c;但深入探究后你会发…...

基于Mayan EDMS的文档管理系统部署与优化实践

1. 项目概述&#xff1a;一个面向文档管理的开源解决方案如果你在寻找一个能够替代Confluence、SharePoint&#xff0c;甚至是Google Drive的开源自托管方案&#xff0c;那么joyozhang333-lgtm/mayan-kin这个项目值得你花时间研究。它不是一个全新的轮子&#xff0c;而是基于一…...

TI毫米波雷达的测距极限:带宽、采样率与最大探测距离到底什么关系?

TI毫米波雷达测距极限&#xff1a;从理论公式到工程实践的深度解析 在自动驾驶和工业传感领域&#xff0c;毫米波雷达因其全天候工作能力和精确测距特性成为核心传感器。德州仪器(TI)的AWR和IWR系列雷达芯片凭借高集成度和灵活配置&#xff0c;被广泛应用于无人机避障、智能停车…...