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

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

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

介紹

在前端vue中有時會遇到需要進行預(yù)覽pdf的場景,前段時間我一位前端朋友就有遇到這個問題,也和我進行了一些探討

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

本地文件,pdf在線預(yù)覽路徑,pdf下載路徑三種,其中前面兩種還比較常見,但是第三種的pdf下載路徑進行預(yù)覽這種場景還是不是太多的,因為他們后端給返回的路徑就是一個下載路徑,路徑放到瀏覽器里面會直接進行下載pdf

下面將會以vue3為例來進行預(yù)覽pdf的演示

安裝環(huán)境

vue3

第三方包組件

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

預(yù)覽pdf

主要組件代碼如下

本地文件預(yù)覽 

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

啟動查看效果

預(yù)覽成功

在線路徑預(yù)覽

 比較常見的就是一個可以直接拿來預(yù)覽的路徑,比如下面的路徑:

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

書寫預(yù)覽代碼

預(yù)覽成功

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

查看預(yù)覽效果

預(yù)覽樣式有些丑需要自己進行書寫樣式,當然本地文件那種也可以使用iframe進行預(yù)覽,可以自己嘗試下

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

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

首先后端準備提供一個下載文件的接口路徑

 @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ù)啟動后將接口路徑直接放入到瀏覽器中回車驗證是否直接進行文件的下載

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

查看預(yù)覽效果:

預(yù)覽成功

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

查看預(yù)覽 

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

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

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

提取碼:42yi

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

相關(guān)文章

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

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

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

    Vue組件通信入門之Provide和Inject機制

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

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

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

    vue中el-tree動態(tài)初始默認選中和全選實現(xiàn)方法

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

    Vue之mixin混入詳解

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

    Vue折疊面板組件的封裝

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

    vue打包使用Nginx代理解決跨域問題

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

    vue如何對一個數(shù)據(jù)過濾出想要的item

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

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

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

    Vue實現(xiàn)簡易計算器

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

最新評論