Vue3實(shí)現(xiàn)預(yù)覽PDF文件的多種方式(超簡(jiǎn)單)
介紹
在前端vue中有時(shí)會(huì)遇到需要進(jìn)行預(yù)覽pdf的場(chǎng)景,前段時(shí)間我一位前端朋友就有遇到這個(gè)問(wèn)題,也和我進(jìn)行了一些探討
其中預(yù)覽pdf場(chǎng)景主要會(huì)有三種情況:
本地文件,pdf在線(xiàn)預(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ù)覽成功
在線(xiàn)路徑預(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組件通信入門(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中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如何對(duì)一個(gè)數(shù)據(jù)過(guò)濾出想要的item
這篇文章主要介紹了vue如何對(duì)一個(gè)數(shù)據(jù)過(guò)濾出想要的item問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
Vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器
這篇文章主要為大家詳細(xì)介紹了用Vue制作的簡(jiǎn)易計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02

