pdfjs-dist的进阶使用:手动触发pdf文件跳转到指定页码

链接

与此相关的文章地址:

背景

通过前面几篇文章中的路线,其实已经实现了使用pdfjs-dist来预览PDF,它与我们通过pre标签等简单预览的直接区别就是:可以包含的功能比较多,如页面跳转、搜索、打开导航窗格等等,就是一个完整的pdf功能。

那么问题来了,在这个插件中进行页面跳转各种操作都行。现在需要在**外部来触发插件内部的事件,实现pdf文件的页面定位**。

举个例子就是:

javascript 复制代码
<button>页面跳转</button>

<iframe id="pdf-container" url="http://pdf-server/show.pdf"></iframe>

iframe是用来承载pdf的容器,但是需要通过一个外部的button,来触发iframe内部的pdf文件翻页。

实现

主要思路就是修改pdfjs-dist源码,然后自己部署。在此次修改中,主要涉及两个问题需要注意:

  1. iframe跨域
  2. pdfjs-dist源码阅读

父组件

在需要触发页面跳转的位置,使用以下代码:

javascript 复制代码
// 获取嵌入pdfjs服务的iframe
const frame = document.getElementById('pdf-container')

// 使用postMessage向pdfjs服务发送消息

// 向pdf发送的数据
const sendData = {
	page: currentPage.value,
	origin: window.location.origin
}
// pdfjs-dist部署的域名
const pdfServer = 'http://xxxxx.amazonaws.com'
frame?.contentWindow?.postMessage(sendData , pdfServer )

子组件:pdfjs-dist

indWindowEvents()方法中,添加以下监听:

javascript 复制代码
// 接收来自父组件的消息
window.addEventListener(
   "message",
   event => {
     console.log("🤑 event = ", event);
     const { data, origin } = event;
     // 判断:当域名相同时才触发下列动作
     if (origin === data.origin) {
     
     	// 从父组件传来的数据中获取page
       let page = data.page;

       if (page === null || page === "" || page > this.toolbar.pagesCount) {
         page = 1;
       }
       document.getElementById("pageNumber").value = page * 1;
       
       this.pdfViewer.currentPageNumber = page * 1;
       
       this.toolbar?.setPageNumber(page * 1, page * 1);
       
       this.secondaryToolbar?.setPageNumber(page * 1);
     }
   },
   { signal }
 );

DONE!!!搞定!

相关推荐
专注API从业者3 小时前
Python + 淘宝 API 开发:自动化采集商品数据的完整流程
大数据·运维·前端·数据挖掘·自动化
烛阴3 小时前
TypeScript高手密技:解密类型断言、非空断言与 `const` 断言
前端·javascript·typescript
样子20184 小时前
Uniapp 之renderjs解决swiper+多个video卡顿问题
前端·javascript·css·uni-app·html
Nicholas684 小时前
flutterAppBar之SystemUiOverlayStyle源码解析(一)
前端
黑客飓风5 小时前
JavaScript 性能优化实战大纲
前端·javascript·性能优化
emojiwoo6 小时前
【前端基础知识系列六】React 项目基本框架及常见文件夹作用总结(图文版)
前端·react.js·前端框架
张人玉6 小时前
XML 序列化与操作详解笔记
xml·前端·笔记
杨荧7 小时前
基于Python的宠物服务管理系统 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python·信息可视化
YeeWang7 小时前
🎉 Eficy 让你的 Cherry Studio 直接生成可预览的 React 页面
前端·javascript
gnip7 小时前
Jenkins部署前端项目实战方案
前端·javascript·架构