如何在vue中使用pdfjs預覽pdf文件
前言
在寫項目的過程中,偶爾會有使用到pdf的文件,當我們想看pdf文件的時候,你的操作是不是先把pdf文件下載下來,通過電腦安裝的專用于打開pdf的軟件來查看pdf文件呢。如果有個需求說不要讓用戶安裝軟件呢,畢竟還是有很多用戶不知道怎么安裝軟件或者這個東西需要什么東西才能打開嘛。ok,有了這樣的需求那我們是不是也得去實現(xiàn)嘛,畢竟這理由咱也沒法反駁啊。
思考
既然都提出來了,那就想想怎么使用咯。既然需要用到pdf。不知道有沒有關于js能夠操作的庫文件來幫我呢?果斷一百度,咱們今天的主角就來了:pdfjs。
庫目錄解析和下載
既然有了方案,那就去研究研究了,首先需要去下載這個庫的文件,下載地址:點我下載。這個頁面會有兩個,一個是兼容舊版的,大家可以根據(jù)自己的實際情況下載啊。
下載后的代碼結構如下圖:
這里面有兩個文件夾:
- build 這里面是pdf核心文件
- web 例子
使用方法
有兩種使用方法,一種是通過核心庫文件自己去實現(xiàn)pdf的預覽,還有一種是通過給的例子去預覽pdf文件。這里呢就以給的例子來預覽pdf文件,如果大家有興趣可以去研究研究怎么用核心文件去實現(xiàn)咯。
文件位置
首先我們需要將下載好的文件放到vue項目的static靜態(tài)目錄下,如下圖:
實際調(diào)用
在需要用到的地方使用如下方式調(diào)用:
var url = encodeURIComponent(window.location.origin+'/other/202101/dc88623a-74c4-49c4-bc95-7e34d9cf6163.pdf') window.open(window.location.origin + window.location.pathname+'static/pdfjs/web/viewer.html?file='+url)
上面的pdf地址為自己放在本地的路徑,這里路徑可以為相對和絕對路徑,上面為絕對路徑
這時就可以看到如下效果啦:
問題
如果這個pdf文件的地址和當前下載的庫文件地址在相同的域下,應該不會有太大問題的,如果不同域下就需要解決跨域的問題了。這里有個地方需要解決就是我們下載的庫文件,找到viewer.js文件中下面的內(nèi)容注釋:
將上圖中紅色框框里面的內(nèi)容注釋。如果服務端給出的是下載地址,那么可以使用iframe嵌套來解決。
總結
其實可以看到跨域的知識有時候還是很有用的,上面就用到了,我剛開始弄的時候怎么都出不來,后面發(fā)現(xiàn)跨域下載不下來。當前還有更多的用法和問題,歡迎大家提出來。
以上就是如何在vue中使用pdfjs預覽pdf文件的詳細內(nèi)容,更多關于vue中使用pdfjs預覽pdf文件的資料請關注腳本之家其它相關文章!
相關文章
vue使用smooth-signature實現(xiàn)移動端橫豎屏電子簽字
這篇文章主要為大家介紹了vue使用smooth-signature實現(xiàn)移動端橫豎屏電子簽字示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10vue-cli或vue項目利用HBuilder打包成移動端app操作
這篇文章主要介紹了vue-cli或vue項目利用HBuilder打包成移動端app操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07vue3+el-table封裝示例詳解(編輯、刪除、查看詳情按鈕一起封裝)
在Vue3中,利用Element?Plus?UI庫封裝表格組件,實現(xiàn)編輯、刪除和查看詳情的功能,通過定義tableData和tableDataHeader來管理表格數(shù)據(jù)和表頭,其中tableData通常從后端獲取,而tableHeader可根據(jù)具體需求自定義,感興趣的朋友跟隨小編一起看看吧2024-09-09