Vue3實現(xiàn)預(yù)覽PDF文件的多種方式(超簡單)
介紹
在前端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中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