base64编码后的pdf文件前端页面展示--pdf.js的应用
最近在整理项目中用到的插件或者使用心得,感觉还是写成博客,能加深新一层的理解。
我先说一下我的需求:由于java后台编译的文件流在手机端加载速度太慢,所以想着可以在前端解析,放在页面展示给用户。
所以,我需要后台传给我的是base64编码的pdf文件。我们知道,单纯靠base64解析pdf文件是解析不了的。所以需要引入另一个pdf解析文件--pdf.js
具体的使用方法大家可以看源码:https://mozilla.github.io/pdf.js/
我试着按源码一步一步的操作的,但发现将build文件夹整体引入,也没有方法解决我的需求。最后,在项目中只引用了pdf.js和pdf.worker.js。引入方式和其他引入js文件一样。
我将我自己的demo放在gitHub上了,有兴趣的可以看一下。这里,我先说一下我的理解。
看了很多关于pdf.js的博客,大部分都是关于引入pdf的路径,然后在前端页面展示出来的。关于base64编码后的pdf文件很少。直接引入pdf文件路径的方法,我就不介绍了,大家可以参考其他博客。我现在介绍一下,经过base64编码后的pdf文件如何在前端页面显示出来。
需要的知识点:大家需要知道 Unit8Array和arrayBuffer
首先说一下Unit8Array:(具体可自己查一下MDN https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Uint8Array)
Uint8Array
数组类型表示一个8位无符号整型数组,创建时内容被初始化为0。创建完后,可以以对象的方式或使用数组下标索引的方式引用数组中的元素。
语法结构:Uint8Array(length);//创建初始化为0的,包含length个元素的无符号整型数组
Uint8Array(typedArray);
Uint8Array(object);
Uint8Array(buffer [, byteOffset [, length]]);
ArrayBuffer:又称类型化数组。
- 数组里面可以放数字、字符串、布尔值以及对象和数组等,ArrayBuffer放0和1组成的二进制数据
- 数组放在堆中,ArrayBuffer则把数据放在栈中(所以取数据时后者快)
- ArrayBuffer初始化后固定大小,数组则可以自由增减。(准确的说,视图才应该跟数组来比较这个特点)
接下来,我贴一下代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 | <! DOCTYPE html> < html lang="en"> < head > < meta charset="UTF-8"> < title >pdf的使用</ title > </ head > < body > < div id="container"> < div id="pop"></ div > </ div > < script src="../js/pdf.js"></ script > < script src="../js/pdf.worker.js"></ script > < script > /*将请求来的base64编码的pdf文件,替换多余的空格和换行(为了兼容其他浏览器) * 再使用浏览器自带的atob()的方式解析 * */ /*转化编码格式*/ function converData(data) { data = data.replace(/[\n\r]/g, ''); var raw = window.atob(data); var rawLength = raw.length; var array = new Unit8Array(new ArrayBuffer(rawLength)); for (var i = 0; i < rawLength ; i++) { array[i] = raw.charCodeAt(i) } return array } /*将解码后的值传给PDFJS.getDocument(),交给pdf.js处理*/ function showPdfFile(data) { var fileContent = converData(data); $('#container').show(); $('#pop').empty(); PDFJS.getDocument(fileContent).then(function getPdfHelloWorld(pdf) { pages = pdf.numPages; for (var i = 1; i < pdf.numPages; i++) { var id = 'page-id' + i; $('#pop').append('<canvas id="' + id + '"></ canvas >'); showAll(url, i, id) } }) } function showAll(url, i, id) { PDFJS.getDocument().then(function getPdfHelloWorld(pdf) { pdf.getPage(page).then(function getPageHelloWorld(page) { var scale = 1.0, viewport = page.getViewport(scale), canvas = document.getElementById(id), context = canvas.getContext('2d'); canvas.height = viewport.height; canvas.width = viewport.width; var renderContext = { canvasContext: context, viewport: viewport } page.render(renderContext) }) }) } </ script > </ body > </ html > |
本文来自博客园,作者:前端加油站,转载请注明原文链接:https://www.cnblogs.com/bllx/p/9280912.html
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· DeepSeek 解答了困扰我五年的技术问题。时代确实变了!
· PPT革命!DeepSeek+Kimi=N小时工作5分钟完成?
· What?废柴, 还在本地部署DeepSeek吗?Are you kidding?
· DeepSeek企业级部署实战指南:从服务器选型到Dify私有化落地
· 程序员转型AI:行业分析