摘要:介紹是一個(gè)使用構(gòu)建的可移植文檔格式查看器。使用的前提是瀏覽器要支持。由社區(qū)驅(qū)動(dòng),并得到的支持。目標(biāo)是創(chuàng)建一個(gè)通用的,基于標(biāo)準(zhǔn)的平臺(tái),用于解析和呈現(xiàn)。
介紹
PDF.js 是一個(gè)使用 HTML5 構(gòu)建的可移植文檔格式(PDF)查看器。使用的前提是瀏覽器要支持 html5。
PDF.js 由社區(qū)驅(qū)動(dòng),并得到 Mozilla Labs 的支持。 目標(biāo)是創(chuàng)建一個(gè)通用的,基于 Web 標(biāo)準(zhǔn)的平臺(tái),用于解析和呈現(xiàn) PDF。
pdfjs
demo
瀏覽器兼容性The goal is to support all HTML5 compliant browsers, but sincefeature support varies per browser/version our support for all PDF featuresvaries as well. If you want to support more browsers than Firefox you"ll needto include compatibility.jswhich has polyfills for missing features. Find the list offeatures needed for PDF.js to properly work and browser tests for thosefeatures at RequiredBrowser Features. In general, the support is below:
我們的目標(biāo)是支持所有 HTML5 兼容的瀏覽器,但是每個(gè)瀏覽器/版本對(duì) PDF 的所有特性的支持是不同的。如果你想支持除了 Firefox 以外的更多種瀏覽器,你需要有 compatibility.js 文件,它有 polyfills 丟失的功能。想查找 PDF.js 正常工作所需的瀏覽器的測(cè)試要求,請(qǐng)參考如下瀏覽器特性的列表:
安裝 npm install pdfjs-dist
引入 import PDFJS from "pdfjs-dist"
上傳
onFileChange() { const file = this.$refs.file.files[0]; this.fileName = file ? file.name : "請(qǐng)選擇文件"; this.file = file }
解析渲染
extractPdfContent() { if(this.file.type != "application/pdf"){ console.error(this.file.name, "is not a pdf file.") return } var fileReader = new FileReader(); fileReader.onload = function() { var typedarray = new Uint8Array(this.result); var pdfContainer = document.getElementById("pdf-viewer"); PDFJS.getDocument(typedarray).then(function(pdf) { // you can now use *pdf* here let arr = [] for(let i = 1; i<= pdf.numPages;i++) { arr.push(pdf.getPage(i)) } //這里的處理是為了避免pdf渲染亂序 Promise.all(arr).then(function(pages) { for(let j = 0; j< pdf.numPages;j++) { let page = pages[j] var viewport = page.getViewport(2.0); var canvasNew = document.createElement("canvas"); canvasNew.style.width = "100%"; canvasNew.id = `pdf_${page.pageNumber}`; canvasNew.height = viewport.height; canvasNew.width = viewport.width; page.render({ canvasContext: canvasNew.getContext("2d"), viewport: viewport }); pdfContainer.appendChild(canvasNew) } }); }) } fileReader.readAsArrayBuffer(this.file); }參考資料
https://mozilla.github.io/pdf...
How to render a full PDF using Mozilla"s pdf.js
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/98328.html
摘要:知識(shí)點(diǎn)總結(jié)一實(shí)現(xiàn)頁面的緩存二移動(dòng)端固定定位的解決方案三表單校驗(yàn)表單驗(yàn)證中文文檔橫向滑動(dòng)的選項(xiàng)卡,以及輸入法定位相關(guān)的插件網(wǎng)當(dāng)?shù)谝粋€(gè)輸入框自動(dòng)獲得光標(biāo)的時(shí)候,彈出的輸入法會(huì)把布局頂上去問題可以左右滑動(dòng)的將項(xiàng)目中引入框架和插件當(dāng)?shù)谝粋€(gè)輸 ======================知識(shí)點(diǎn)總結(jié)=========================== 一、keep-alive(實(shí)現(xiàn)頁面的緩存) ...
摘要:用將文檔轉(zhuǎn)換本例使用。在和環(huán)境下測(cè)試通過。轉(zhuǎn)換命令源文件放在或者封裝了一組轉(zhuǎn)換命令,通過調(diào)用相關(guān)服務(wù)。安裝檢查已有字體庫復(fù)制字體新建文件夾把系統(tǒng)的字體復(fù)制進(jìn)去。 用LibreOffice將Office文檔轉(zhuǎn)換PDF 本例使用 LibreOffice-6.0.4、jodconverter-4.2.0、spring-boot-1.5.9.RELEASE。 在CentOS7 + ope...
摘要:備忘錄模式常常與命令模式和迭代子模式一同使用。自述歷史所謂自述歷史模式實(shí)際上就是備忘錄模式的一個(gè)變種。在備忘錄模式中,發(fā)起人角色負(fù)責(zé)人角色和備忘錄角色都是獨(dú)立的角色。 備忘錄模式(Memento Pattern)屬于行為型模式的一種,在不破壞封裝特性的前提下,捕獲一個(gè)對(duì)象的內(nèi)部狀態(tài),并在該對(duì)象之外保存這個(gè)狀態(tài)。這樣就可以將該對(duì)象恢復(fù)到原先保存的狀態(tài)。 概述 備忘錄模式又叫做快照模式(...
摘要:步驟如下下載插件下載地址文件部署建新文件夾,將插件文件放入新建的文件夾。新建在文件代碼如下使用指南檸檬課件打開將文件放到下點(diǎn)擊瀏覽即可。注意因?yàn)樾枰蕾噮f(xié)議。搭個(gè)服務(wù),或者用的瀏覽就可以了。 PDF.js是一款基于HTML5建立的PDF閱讀器,兼容大部分主流的瀏覽器,使用起來,也相對(duì)簡單。步驟如下: 1.下載PDF.js插件 下載地址:http://mozilla.github.io/...
閱讀 733·2023-04-25 20:32
閱讀 2297·2021-11-24 10:27
閱讀 4538·2021-09-29 09:47
閱讀 2252·2021-09-28 09:36
閱讀 3655·2021-09-22 15:27
閱讀 2773·2019-08-30 15:54
閱讀 382·2019-08-30 11:06
閱讀 1280·2019-08-30 10:58