vue預(yù)覽本地pdf文件方法之vue-pdf組件使用
更新時間:2024年03月21日 11:20:16 作者:菜鳥茜
這篇文章主要介紹了vue預(yù)覽本地pdf文件方法之vue-pdf組件使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
1、npm安裝
npm install --save vue-pdf
2、頁面引入

3、具體實現(xiàn)
<div class="pdf" v-show="fileType === 'pdf'">
<p class="arrow">
<span @click="changePdfPage(0)" class="turn"
:class="{grey: currentPage==1}">Preview</span>
{{currentPage}} / {{pageCount}}
<span @click="changePdfPage(1)" class="turn"
:class="{grey: currentPage==pageCount}">Next</span>
</p>
<pdf :src="pdfSrc" :page="currentPage" @num-pages="pageCount=$event"
@page-loaded="currentPage=$event" @loaded="loadPdfHandler">
</pdf>
</div>4、method方法
// 改變PDF頁碼,val傳過來區(qū)分上一頁下一頁的值,0上一頁,1下一頁
changePdfPage (val) {
// console.log(val)
if (val === 0 && this.currentPage > 1) {
this.currentPage--
// console.log(this.currentPage)
}
if (val === 1 && this.currentPage < this.pageCount) {
this.currentPage++
// console.log(this.currentPage)
}
},
// pdf加載時
loadPdfHandler (e) {
this.currentPage = 1 // 加載的時候先加載第一頁
},5、完整代碼
<template>
<div>
<div style="text-align: left;">
<H2>行業(yè)資料</H2>
<el-divider>
</el-divider>
<el-container>
<el-aside width="300px" style="border: 1px solid #eee;height: 1000px; background-color: #D3DCE6;">
<div class="myTree">
<el-tree default-expand-all :props="defaultProps" :data="tableData" @node-click="handleNodeClick"></el-tree>
</div>
</el-aside>
<el-container style="border: 1px solid #eee;margin-left: 10px;">
<div class="pdf" v-show="fileType === 'pdf'">
<p class="arrow">
<span :class="{grey: currentPage==1}" @click="changePdfPage(0)" class="turn">Preview</span>
{{currentPage}} / {{pageCount}}
<span :class="{grey: currentPage==pageCount}" @click="changePdfPage(1)" class="turn">Next</span>
</p>
<pdf
:page="currentPage"
:src="pdfSrc"
@loaded="loadPdfHandler"
@num-pages="pageCount=$event"
@page-loaded="currentPage=$event">
</pdf>
</div>
</el-container>
</el-container>
</div>
</div>
</template><script>
import pdf from 'vue-pdf'
export default {
name: "IndustryInformation",
components: {pdf},
data(){
return {
currentPage: 0, // pdf文件頁碼
pageCount: 0, // pdf文件總頁數(shù)
fileType: 'pdf', // 文件類型
pdfSrc: '', // pdf文件地址
defaultProps: {
children: 'children',
label: 'name'
},
tableData: [{
id: 1,
name: '道路工程資料',
children:[
{
id: 2,
name: '公路工程資料編制概述',
children:[
{
id: 21,
name: '路面工程部分分項劃分表',
src: '/1.pdf',
},
{
id: 13,
name: '一般建設(shè)項目單位工程劃分表',
src: '/2.pdf',
},
{
id: 14,
name: '路基工程部分分項劃分表',
src: '/3.pdf',
},
{
id: 33,
name: '橋梁工程部分分項劃分表',
src: '/4.pdf',
},
{
id: 34,
name: '隧道工程部分分項劃分表',
src: '/5.pdf',
}
]
},
{
id: 3,
name: '公路工程竣工資料',
children:[
{
id: 7,
name: '公路工程竣工文件編排層次',
src: '/5.pdf',
},
{
id: 8,
name: '工程洽商記錄表',
src: '/4.pdf',
},
{
id: 9,
name: '工程設(shè)計表更、洽商一覽表',
src: '/3.pdf',
}
]
}
]}]
}
},
methods:{
// 改變PDF頁碼,val傳過來區(qū)分上一頁下一頁的值,0上一頁,1下一頁
changePdfPage(val) {
// console.log(val)
if (val === 0 && this.currentPage > 1) {
this.currentPage--
// console.log(this.currentPage)
}
if (val === 1 && this.currentPage < this.pageCount) {
this.currentPage++
// console.log(this.currentPage)
}
},
// pdf加載時
loadPdfHandler(e) {
this.currentPage = 1 // 加載的時候先加載第一頁
},
handleNodeClick(data) {
this.pdfSrc = data.src;
}
}
}
</script><style scoped>
.myTree /deep/ .el-tree {
position: relative;
cursor: default;
color: #606266;
background-color: #D3DCE6;
}
</style>6、最終效果

后記:
主要是priview和next翻頁不是我想要的效果,因此只能另尋它法。
注意:
pdf文件需要放在public路徑下任意文件夾中,不支持相對路徑
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue element-ui實現(xiàn)input輸入框金額數(shù)字添加千分位
這篇文章主要介紹了vue element-ui實現(xiàn)input輸入框金額數(shù)字添加千分位,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12
vue-cli創(chuàng)建的項目,配置多頁面的實現(xiàn)方法
下面小編就為大家分享一篇vue-cli創(chuàng)建的項目,配置多頁面的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間)
這篇文章主要給大家介紹了關(guān)于Vue組件間通信的相關(guān)資料,其中包括父子組件、兄弟組件及祖先后代組件間的通信,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
vue的template模板是如何轉(zhuǎn)為render函數(shù)的過程
Vue從template到render函數(shù)的轉(zhuǎn)換經(jīng)歷模板解析、AST構(gòu)建、優(yōu)化、生成渲染函數(shù)等步驟,首先進行詞法分析將模板拆解為tokens,再進行語法分析構(gòu)建AST,然后對AST進行靜態(tài)標(biāo)記和提升優(yōu)化,最后轉(zhuǎn)換成JavaScript渲染函數(shù),生成虛擬DOM,完成組件的渲染和更新,實現(xiàn)了模板的高效轉(zhuǎn)化2024-10-10

