欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端預(yù)覽pdf文件流詳細步驟

 更新時間:2023年09月28日 09:48:31   作者:valsedefleurs  
公司最近有這么個需求,在線預(yù)覽pdf功能,正好有點時間,稍微整理記錄一下,這篇文章主要給大家介紹了關(guān)于前端預(yù)覽pdf文件流的相關(guān)資料,需要的朋友可以參考下

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)詳解

    這篇文章主要為大家介紹了validate?注冊頁的表單數(shù)據(jù)校驗實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vuex 動態(tài)注冊方法 registerModule的實現(xiàn)

    vuex 動態(tài)注冊方法 registerModule的實現(xiàn)

    這篇文章主要介紹了vuex 動態(tài)注冊方法 registerModule的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Vue中代碼傳送(teleport)的實現(xiàn)

    Vue中代碼傳送(teleport)的實現(xiàn)

    本文主要介紹了Vue中代碼傳送(teleport)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Vue+Koa+MongoDB從零打造一個任務(wù)管理系統(tǒng)的詳細過程

    Vue+Koa+MongoDB從零打造一個任務(wù)管理系統(tǒng)的詳細過程

    這篇文章主要介紹了Vue+Koa+MongoDB從零打造一個任務(wù)管理系統(tǒng),本文通過圖文實例代碼相結(jié)合給大家介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • vue3+ts+elementPLus實現(xiàn)v-preview指令

    vue3+ts+elementPLus實現(xiàn)v-preview指令

    本文主要介紹了vue3+ts+elementPLus實現(xiàn)v-preview指令,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Vue項目中如何封裝axios(統(tǒng)一管理http請求)

    Vue項目中如何封裝axios(統(tǒng)一管理http請求)

    這篇文章主要給大家介紹了關(guān)于Vue項目中如何封裝axios(統(tǒng)一管理http請求)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • vue如何使用cookie、localStorage和sessionStorage進行儲存數(shù)據(jù)

    vue如何使用cookie、localStorage和sessionStorage進行儲存數(shù)據(jù)

    這篇文章主要介紹了vue如何使用cookie、localStorage和sessionStorage進行儲存數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue中動態(tài)綁定表單元素的屬性方法

    vue中動態(tài)綁定表單元素的屬性方法

    下面小編就為大家分享一篇vue中動態(tài)綁定表單元素的屬性方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Vue關(guān)閉當前頁面的方法

    Vue關(guān)閉當前頁面的方法

    Vue中關(guān)閉當前頁面的方法與原生JavaScript類似,都是通過window對象的close方法實現(xiàn),這篇文章主要介紹了Vue關(guān)閉當前頁面的方法,需要的朋友可以參考下
    2023-09-09
  • electron踩坑之dialog中的callback解決

    electron踩坑之dialog中的callback解決

    這篇文章主要介紹了electron踩坑之dialog中的callback解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10

最新評論