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

Vue3實(shí)現(xiàn)預(yù)覽PDF文件的多種方式(超簡(jiǎn)單)

 更新時(shí)間:2025年03月11日 10:26:04   作者:暗武逢天  
在Vue項(xiàng)目中實(shí)現(xiàn)PDF文件預(yù)覽是許多開(kāi)發(fā)者可能會(huì)遇到的需求,尤其是在開(kāi)發(fā)海外后臺(tái)管理系統(tǒng)時(shí),由于某些用戶(hù)上傳的文件格式為PDF,而Vue本身并不直接支持PDF文件的預(yù)覽功能,這就需要借助一些第三方的插件或者工具來(lái)完成,下面詳細(xì)地介紹幾種在Vue3中實(shí)現(xiàn)PDF文件預(yù)覽的方法

介紹

在前端vue中有時(shí)會(huì)遇到需要進(jìn)行預(yù)覽pdf的場(chǎng)景,前段時(shí)間我一位前端朋友就有遇到這個(gè)問(wèn)題,也和我進(jìn)行了一些探討

其中預(yù)覽pdf場(chǎng)景主要會(huì)有三種情況:

本地文件,pdf在線預(yù)覽路徑,pdf下載路徑三種,其中前面兩種還比較常見(jiàn),但是第三種的pdf下載路徑進(jìn)行預(yù)覽這種場(chǎng)景還是不是太多的,因?yàn)樗麄兒蠖私o返回的路徑就是一個(gè)下載路徑,路徑放到瀏覽器里面會(huì)直接進(jìn)行下載pdf

下面將會(huì)以vue3為例來(lái)進(jìn)行預(yù)覽pdf的演示

安裝環(huán)境

vue3

第三方包組件

npm install vue-pdf-embed@^1.1.6
 
npm install vue3-pdfjs@^0.1.6

預(yù)覽pdf

主要組件代碼如下

本地文件預(yù)覽 

首先第一種情況,直接把pdf文件放入項(xiàng)目目錄中進(jìn)行預(yù)覽

啟動(dòng)查看效果

預(yù)覽成功

在線路徑預(yù)覽

 比較常見(jiàn)的就是一個(gè)可以直接拿來(lái)預(yù)覽的路徑,比如下面的路徑:

http://static.shanhuxueyuan.com/test.pdf

書(shū)寫(xiě)預(yù)覽代碼

預(yù)覽成功

當(dāng)然也可以使用系統(tǒng)自帶的iframe進(jìn)行預(yù)覽

查看預(yù)覽效果

預(yù)覽樣式有些丑需要自己進(jìn)行書(shū)寫(xiě)樣式,當(dāng)然本地文件那種也可以使用iframe進(jìn)行預(yù)覽,可以自己嘗試下

下載文件路徑預(yù)覽

極少數(shù)情況下拿到的是一個(gè)直接下載的路徑,此時(shí)前端不想進(jìn)行下載想直接對(duì)該路徑進(jìn)行預(yù)覽,當(dāng)然前面的組件也完全可以兼容這種寫(xiě)法

首先后端準(zhǔn)備提供一個(gè)下載文件的接口路徑

 @GetMapping("/downloadPdf")
    public ResponseEntity<StreamingResponseBody> downloadPdf() {
        // 指定本地 PDF 文件的路徑
        String filePath = "C:\\var\\示例2.pdf";
        File file = new File(filePath);
 
        // 檢查文件是否存在
        if (!file.exists()) {
            return ResponseEntity.notFound().build();
        }
 
        // 設(shè)置響應(yīng)頭
        HttpHeaders headers = new HttpHeaders();
        headers.add(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=test.pdf");
        headers.add("Cache-Control", "no-cache, no-store, must-revalidate");
        headers.add("Pragma", "no-cache");
        headers.add("Expires", "0");
 
        // 返回 StreamingResponseBody
        StreamingResponseBody body = outputStream -> {
            try (FileInputStream fis = new FileInputStream(file)) {
                byte[] buffer = new byte[4096];
                int bytesRead;
                while ((bytesRead = fis.read(buffer)) != -1) {
                    outputStream.write(buffer, 0, bytesRead);
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        };
 
        return ResponseEntity.ok()
                .headers(headers)
                .contentLength(file.length())
                .contentType(MediaType.APPLICATION_OCTET_STREAM)
                .body(body);
    }

服務(wù)啟動(dòng)后將接口路徑直接放入到瀏覽器中回車(chē)驗(yàn)證是否直接進(jìn)行文件的下載

下載成功表示該路徑就是一個(gè)直接下載的路徑

查看預(yù)覽效果:

預(yù)覽成功

但是此時(shí)嵌套一般的iframe組件就不行了

查看預(yù)覽 

預(yù)覽失敗,瀏覽器直接下載文件了

學(xué)習(xí)源碼

https://pan.baidu.com/s/102c33vGw2lvaPD1aH__t4A

提取碼:42yi

以上就是Vue3實(shí)現(xiàn)預(yù)覽PDF文件的多種方式(超簡(jiǎn)單)的詳細(xì)內(nèi)容,更多關(guān)于Vue3預(yù)覽PDF文件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue-cli的工程模板與構(gòu)建工具詳解

    vue-cli的工程模板與構(gòu)建工具詳解

    vue-cli提供的腳手架只是一個(gè)最基礎(chǔ)的,也可以說(shuō)是Vue團(tuán)隊(duì)認(rèn)為的工程結(jié)構(gòu)的一種最佳實(shí)踐。這篇文章主要介紹了vue-cli的工程模板與構(gòu)建工具 ,需要的朋友可以參考下
    2018-09-09
  • Vue組件通信入門(mén)之Provide和Inject機(jī)制

    Vue組件通信入門(mén)之Provide和Inject機(jī)制

    這篇文章主要給大家介紹了關(guān)于Vue組件通信入門(mén)之Provide和Inject機(jī)制的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Vue組件通信具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Vue安裝瀏覽器開(kāi)發(fā)工具的步驟詳解

    Vue安裝瀏覽器開(kāi)發(fā)工具的步驟詳解

    這篇文章主要介紹了Vue安裝瀏覽器開(kāi)發(fā)工具步驟詳解,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • vue中el-tree動(dòng)態(tài)初始默認(rèn)選中和全選實(shí)現(xiàn)方法

    vue中el-tree動(dòng)態(tài)初始默認(rèn)選中和全選實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于vue中el-tree動(dòng)態(tài)初始默認(rèn)選中和全選實(shí)現(xiàn)的相關(guān)資料,eltree默認(rèn)選中eltree是一種常用的樹(shù)形控件,通常用于在網(wǎng)頁(yè)上呈現(xiàn)樹(shù)形結(jié)構(gòu)的數(shù)據(jù),例如文件夾、目錄、組織結(jié)構(gòu)等,需要的朋友可以參考下
    2023-09-09
  • Vue之mixin混入詳解

    Vue之mixin混入詳解

    這篇文章主要為大家介紹了Vue之mixin混入,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-11-11
  • Vue折疊面板組件的封裝

    Vue折疊面板組件的封裝

    這篇文章主要為大家詳細(xì)介紹了Vue折疊面板組件的封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue打包使用Nginx代理解決跨域問(wèn)題

    vue打包使用Nginx代理解決跨域問(wèn)題

    這篇文章主要介紹了vue打包使用Nginx代理解決跨域問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • vue如何對(duì)一個(gè)數(shù)據(jù)過(guò)濾出想要的item

    vue如何對(duì)一個(gè)數(shù)據(jù)過(guò)濾出想要的item

    這篇文章主要介紹了vue如何對(duì)一個(gè)數(shù)據(jù)過(guò)濾出想要的item問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 如何在JS文件中獲取Vue組件

    如何在JS文件中獲取Vue組件

    這篇文章主要介紹了如何在JS文件中獲取Vue組件,幫助大家更好的理解和學(xué)習(xí)前端知識(shí),感興趣的朋友可以了解下
    2020-09-09
  • Vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器

    Vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了用Vue制作的簡(jiǎn)易計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02

最新評(píng)論