前端預(yù)覽pdf文件流詳細步驟
1. PDF組件選型
通過查找資料,可以找到如下幾種方案,其中最為成熟的方案是vue-pdf
1. iframe 既可以用來瀏覽本地static下的文檔,也可以預(yù)覽后端返回的文件流文檔
2. vue-pdf 較為完善的vue預(yù)覽pdf的方案
3. vueshowpdf 網(wǎng)絡(luò)上找到的一個他人封裝的pdf組件
優(yōu)點 | 缺點 | 原理 | |
iframe/object/embed | 簡單易用,包含了翻頁,打印,縮放等內(nèi)嵌功能 | 無法禁止打印 | 將pdf作為插件內(nèi)嵌再這三個HTML標簽內(nèi) |
vueshowpdf | 樣式簡單清爽,包含翻頁,縮放功能,可以禁止打印 | 在不修改源碼的情況下無法自定義相關(guān)樣式,無進度加載提示,加載完成前會出現(xiàn)白屏 | 基于底層pdf.js實現(xiàn) |
vue-pdf | 樣式組件可自定義,包含加載進度,翻頁,頁內(nèi)元素可交互等 | 固定寬高的比例,需要將包裹pdf的父容器盡可能調(diào)大才能顯示完全 | 基于pdf.js實現(xiàn) |
總結(jié)下來,
- 如果只想 簡單在頁面嵌套PDF,使用iframe/object/embed是最好的選擇,它不需要你自己去編寫翻頁組件,不需要去調(diào)整樣式,用戶體驗佳。
- 如果對 樣式?jīng)]有定制化 的需求,使用 vueshowpdf 也是非常不錯,彈窗式的UI看起來會更加高大上。
- 如果對 權(quán)限控制,樣式定制需求高,使用 vue-pdf 是最好的選擇,接口和屬性較全,擴展能力強,自由度高。
2. Iframe使用步驟
2.1 使用與邏輯
邏輯:將后端返回的看不懂的文件流,設(shè)置成reponseType="arraybuffer",然后讀取到返回的blob,再使用createObjectURL讀取出url即可
2.2 代碼示例
<template> <iframe :src="src" frameborder="0" :style="iframeStyle" /> </template> <script> import { mapState } from 'vuex' import { getNodeObjectData } from '@/modules/viewer/apis/service' export default { name: 'pdfPanel', props: { node: { type: Object, default: () => {} } }, data() { return { src: '' } }, computed: { ...mapState({ innerHeight: (state) => state.viewerStore.setting['innerHeight'] }), iframeStyle() { return { width: '100%', height: `${this.innerHeight - 130}px` } } }, mounted() { return getNodeObjectData({ meta_id: this.node.id }) .then((res) => { const blob = new Blob([res], { type: 'application/pdf' }) const url = window.URL.createObjectURL(blob) this.src = url }) }, methods: { handleFullScreen() { window.open(`${this.src}#filename=${this.node.name}`, "_blank") } } } </script>>
2.3 圖文詳解
1. 后端返回的是文件流,如下:
2. 接口請求設(shè)置responseType="arraybuffer"
export function getNodeObjectData(params) { return axios({ url: `${apiPrefix}/pdf`, method: 'GET', params: params, responseType: 'arraybuffer' }) }
總結(jié)
到此這篇關(guān)于前端預(yù)覽pdf文件流的文章就介紹到這了,更多相關(guān)前端預(yù)覽pdf文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
validate?注冊頁的表單數(shù)據(jù)校驗實現(xiàn)詳解
這篇文章主要為大家介紹了validate?注冊頁的表單數(shù)據(jù)校驗實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09vuex 動態(tài)注冊方法 registerModule的實現(xiàn)
這篇文章主要介紹了vuex 動態(tài)注冊方法 registerModule的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Vue+Koa+MongoDB從零打造一個任務(wù)管理系統(tǒng)的詳細過程
這篇文章主要介紹了Vue+Koa+MongoDB從零打造一個任務(wù)管理系統(tǒng),本文通過圖文實例代碼相結(jié)合給大家介紹的非常詳細,需要的朋友可以參考下2022-08-08vue3+ts+elementPLus實現(xiàn)v-preview指令
本文主要介紹了vue3+ts+elementPLus實現(xiàn)v-preview指令,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05Vue項目中如何封裝axios(統(tǒng)一管理http請求)
這篇文章主要給大家介紹了關(guān)于Vue項目中如何封裝axios(統(tǒng)一管理http請求)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05vue如何使用cookie、localStorage和sessionStorage進行儲存數(shù)據(jù)
這篇文章主要介紹了vue如何使用cookie、localStorage和sessionStorage進行儲存數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08