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!!!搞定!

相关推荐
烂蜻蜓3 分钟前
前端已死?什么是前端
开发语言·前端·javascript·vue.js·uni-app
谢尔登1 小时前
Vue 和 React 的异同点
前端·vue.js·react.js
Pro_er5 小时前
Vue3响应式编程三剑客:计算属性、方法与侦听器深度实战指南
vue·前端开发
企鹅侠客5 小时前
开源免费文档翻译工具 可支持pdf、word、excel、ppt
人工智能·pdf·word·excel·自动翻译
祈澈菇凉5 小时前
Webpack的基本功能有哪些
前端·javascript·vue.js
小纯洁w6 小时前
Webpack 的 require.context 和 Vite 的 import.meta.glob 的详细介绍和使用
前端·webpack·node.js
想睡好6 小时前
css文本属性
前端·css
qianmoQ6 小时前
第三章:组件开发实战 - 第五节 - Tailwind CSS 响应式导航栏实现
前端·css
zhoupenghui1686 小时前
golang时间相关函数总结
服务器·前端·golang·time
White graces7 小时前
正则表达式效验邮箱格式, 手机号格式, 密码长度
前端·spring boot·spring·正则表达式·java-ee·maven·intellij-idea