vue 實(shí)現(xiàn)pdf預(yù)覽和下載

1. 前言

  1. 雖然我自己找工作的時(shí)候沒有問到此問題,但是有些道友私下wei我了,每次解釋比較麻煩,還是單獨(dú)寫篇文章吧
  2. 誰讓前端啥都能干呢

2. 準(zhǔn)備工作

  1. 主要框架vue3
  2. pdf第三方庫:PDF.js 是一個(gè)開源的 JavaScript 庫辉饱,可以在網(wǎng)頁上直接加載渲染 PDF 文件洁桌。
    3.通過引入 PDF.js 庫并使用其提供的 API巧还,在 Vue 組件中實(shí)現(xiàn) PDF 的預(yù)覽功能
  3. 安裝依賴 注意 依賴名字
npm install pdfjs-dist

3. vue組件 ---預(yù)覽

<template>
  <div>
    <div ref="pdfContainer"></div>
  </div>
</template>

<script setup>
import { ref, onMounted } from 'vue';
import * as pdfjs from 'pdfjs-dist/build/pdf';

const pdfUrl = '/path/to/pdf.pdf';

const pdfContainer = ref(null);

onMounted(() => {
  const pdfViewer = new pdfjs.PDFViewer({
    container: pdfContainer.value,
  });

  pdfjs.getDocument(pdfUrl).promise.then((pdf) => {
    pdfViewer.setDocument(pdf);
  });
});
</script>

  1. 使用了pdfjs-dist庫來加載和渲染 PDF 文件。
    2.在 onMounted 鉤子中蜕猫,我們創(chuàng)建了一個(gè) PDFViewer 實(shí)例
    3.并將 PDF 文件渲染到指定的容器
  1. 這只寫了 PDF 文件的預(yù)覽功能,你還可以根據(jù)需要對預(yù)覽界面進(jìn)行進(jìn)一步的樣式和交互優(yōu)化。同時(shí)傻工,確保將實(shí)際的 PDF 文件路徑(pdfUrl)替換為你自己的路徑

4. iframe 實(shí)現(xiàn)預(yù)覽

  1. 使用 iframe 元素加載 PDF 文件。通過將 PDF 文件的 URL 設(shè)置為iframesrc 屬性,可以在網(wǎng)頁上嵌入 PDF 文件并實(shí)現(xiàn)預(yù)覽功能中捆。
  2. 相關(guān)代碼
<template>
  <div>
    <iframe ref="pdfViewer" :src="pdfUrl"></iframe>
  </div>
</template>

<script setup>
import { ref } from 'vue';

const pdfUrl = '/path/to/pdf.pdf';

const pdfViewer = ref(null);
</script>

<style scoped>
iframe {
  width: 100%;
  height: 100%;
  border: none;
}
</style>

  1. 使用 ref 來引用 iframe 元素鸯匹,并將 PDF 文件的 URL 綁定到 iframe 的 src 屬性上。
  2. 這樣就可以在頁面中嵌入 PDF 文件并實(shí)現(xiàn)預(yù)覽功能泄伪。你可以根據(jù)需要調(diào)整 iframe 的樣式和大小殴蓬。
  • 使用 iframe 預(yù)覽 PDF 文件可能受到瀏覽器安全策略的限制,具體行為可能因?yàn)g覽器而異蟋滴。


5. 下載功能實(shí)現(xiàn)

  • 前端下載其實(shí)都很方便的

使用 <a> 標(biāo)簽

  1. 最簡單的方式是使用 <a>標(biāo)簽來創(chuàng)建一個(gè)下載鏈接染厅,
  2. 將 PDF 文件的 URL 設(shè)置為該鏈接的 href 屬性。
  3. 用戶點(diǎn)擊鏈接時(shí)津函,瀏覽器會(huì)自動(dòng)下載 PDF 文件
<template>
  <div>
    <a :href="pdfUrl" download="filename.pdf">下載PDF</a>
  </div>
</template>

<script setup>
import { ref } from 'vue';

const pdfUrl = '/path/to/pdf.pdf';
</script>

  1. 使用 <a> 標(biāo)簽創(chuàng)建一個(gè)下載鏈接肖粮,并將 PDF文件的 URL綁定到 href 屬性上。
  2. 通過設(shè)置 download 屬性尔苦,可以指定下載的文件名涩馆。
  3. 用戶點(diǎn)擊鏈接時(shí),瀏覽器會(huì)自動(dòng)下載指定的 PDF 文件允坚。
  • 確保將實(shí)際的 PDF 文件路徑(pdfUrl)替換為你自己的路徑魂那,并根據(jù)需要自定義下載鏈接的樣式。

使用 JavaScript 下載

  1. 如果你需要在用戶執(zhí)行某個(gè)操作后觸發(fā) PDF 文件的下載稠项,可以使用 JavaScript 來實(shí)現(xiàn)文件下載功能涯雅。
  2. 這可以通過創(chuàng)建臨時(shí)的Blob對象和使用 URL.createObjectURL()方法來實(shí)現(xiàn)
<template>
  <div>
    <button @click="downloadPdf">下載PDF</button>
  </div>
</template>

<script setup>
import { ref } from 'vue';

const pdfUrl = '/path/to/pdf.pdf';

const downloadPdf = () => {
  const xhr = new XMLHttpRequest();
  xhr.open('GET', pdfUrl, true);
  xhr.responseType = 'blob';

  xhr.onload = () => {
    if (xhr.status === 200) {
      const blob = new Blob([xhr.response], { type: 'application/pdf' });
      const url = URL.createObjectURL(blob);

      const link = document.createElement('a');
      link.href = url;
      link.download = 'filename.pdf';
      link.click();

      URL.revokeObjectURL(url);
    }
  };

  xhr.send();
};
</script>

  1. 定義了 downloadPdf方法,在用戶點(diǎn)擊按鈕時(shí)觸發(fā)該方法皿渗。
  2. 方法內(nèi)部使用 XMLHttpRequest對象進(jìn)行異步請求斩芭,獲取 PDF 文件的 Blob 數(shù)據(jù)。
  3. 然后乐疆,通過創(chuàng)建 <a> 標(biāo)簽划乖,將 Blob對象的 URL 設(shè)置為鏈接的 href 屬性,
  4. 再使用click()方法模擬點(diǎn)擊下載挤土。

請注意琴庵,將實(shí)際的 PDF 文件路徑(pdfUrl)替換為你自己的路徑,并根據(jù)需要自定義觸發(fā)下載操作的方式和樣式仰美。


6. 服務(wù)端下載

  1. 前端通過調(diào)用后端接口來實(shí)現(xiàn)下載也是常用的方式

參考資料


初心

我所有的文章都只是基于入門迷殿,初步的了解;是自己的知識體系梳理,如有錯(cuò)誤,道友們一起溝通交流;
如果能幫助到有緣人,非常的榮幸,一切為了部落的崛起;
共勉
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末咖杂,一起剝皮案震驚了整個(gè)濱河市庆寺,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌诉字,老刑警劉巖懦尝,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件知纷,死亡現(xiàn)場離奇詭異,居然都是意外死亡陵霉,警方通過查閱死者的電腦和手機(jī)琅轧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來踊挠,“玉大人乍桂,你說我怎么就攤上這事⌒Т玻” “怎么了睹酌?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長剩檀。 經(jīng)常有香客問我忍疾,道長,這世上最難降的妖魔是什么谨朝? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮甥绿,結(jié)果婚禮上字币,老公的妹妹穿的比我還像新娘。我一直安慰自己共缕,他們只是感情好洗出,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著图谷,像睡著了一般翩活。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上便贵,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天菠镇,我揣著相機(jī)與錄音,去河邊找鬼承璃。 笑死利耍,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的盔粹。 我是一名探鬼主播隘梨,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼舷嗡!你這毒婦竟也來了轴猎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤进萄,失蹤者是張志新(化名)和其女友劉穎捻脖,沒想到半個(gè)月后锐峭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡郎仆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年只祠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片扰肌。...
    茶點(diǎn)故事閱讀 39,703評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡抛寝,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出曙旭,到底是詐尸還是另有隱情盗舰,我是刑警寧澤,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布桂躏,位于F島的核電站钻趋,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏剂习。R本人自食惡果不足惜蛮位,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鳞绕。 院中可真熱鬧失仁,春花似錦、人聲如沸们何。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽冤竹。三九已至拂封,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間鹦蠕,已是汗流浹背冒签。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留片部,地道東北人镣衡。 一個(gè)月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像档悠,于是被迫代替她去往敵國和親廊鸥。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內(nèi)容