Vue3實(shí)現(xiàn)預(yù)覽PDF文件的多種方式(超簡單)
介紹
在前端vue中有時會遇到需要進(jìn)行預(yù)覽pdf的場景,前段時間我一位前端朋友就有遇到這個問題,也和我進(jìn)行了一些探討
其中預(yù)覽pdf場景主要會有三種情況:
本地文件,pdf在線預(yù)覽路徑,pdf下載路徑三種,其中前面兩種還比較常見,但是第三種的pdf下載路徑進(jìn)行預(yù)覽這種場景還是不是太多的,因?yàn)樗麄兒蠖私o返回的路徑就是一個下載路徑,路徑放到瀏覽器里面會直接進(jìn)行下載pdf
下面將會以vue3為例來進(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ù)覽

啟動查看效果

預(yù)覽成功
在線路徑預(yù)覽
比較常見的就是一個可以直接拿來預(yù)覽的路徑,比如下面的路徑:
http://static.shanhuxueyuan.com/test.pdf

書寫預(yù)覽代碼


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

查看預(yù)覽效果

預(yù)覽樣式有些丑需要自己進(jìn)行書寫樣式,當(dāng)然本地文件那種也可以使用iframe進(jìn)行預(yù)覽,可以自己嘗試下
下載文件路徑預(yù)覽
極少數(shù)情況下拿到的是一個直接下載的路徑,此時前端不想進(jìn)行下載想直接對該路徑進(jìn)行預(yù)覽,當(dāng)然前面的組件也完全可以兼容這種寫法
首先后端準(zhǔn)備提供一個下載文件的接口路徑
@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àn)證是否直接進(jìn)行文件的下載

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

查看預(yù)覽效果:

預(yù)覽成功
但是此時嵌套一般的iframe組件就不行了

查看預(yù)覽

預(yù)覽失敗,瀏覽器直接下載文件了
學(xué)習(xí)源碼
https://pan.baidu.com/s/102c33vGw2lvaPD1aH__t4A
提取碼:42yi
以上就是Vue3實(shí)現(xiàn)預(yù)覽PDF文件的多種方式(超簡單)的詳細(xì)內(nèi)容,更多關(guān)于Vue3預(yù)覽PDF文件的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue組件通信入門之Provide和Inject機(jī)制
這篇文章主要給大家介紹了關(guān)于Vue組件通信入門之Provide和Inject機(jī)制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Vue組件通信具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
vue中el-tree動態(tài)初始默認(rèn)選中和全選實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于vue中el-tree動態(tài)初始默認(rèn)選中和全選實(shí)現(xiàn)的相關(guān)資料,eltree默認(rèn)選中eltree是一種常用的樹形控件,通常用于在網(wǎng)頁上呈現(xiàn)樹形結(jié)構(gòu)的數(shù)據(jù),例如文件夾、目錄、組織結(jié)構(gòu)等,需要的朋友可以參考下2023-09-09

