功能描述
最近在项目开发中,客户有这样一个需求:在线预览上传上去的PDF文件,之前没接触过这块,通过查阅资料,发现有个PDF预览组件,只需要引入进来就可以,下面来进入到干货模式!!!
前端代码
第一步
在components下创建PdfView文件夹,并创建一个.vue文件
第二步
将下面的代码复制到(index.vue).vue文件里,
<template>
<div style="background-color: #FFFFFF;width: 100%;margin: 0 auto;">
<pdf
:page="pageNum"
:src="url"
@progress="loadedRatio = $event"
@num-pages="pageTotalNum=$event"
></pdf>
<br>
<el-button-group style="position: relative;top: 8%;left: 43%;transform: translate(-50%,-50%);">
<el-button type="primary" icon="el-icon-arrow-left" size="mini" @click="prePage">上一页</el-button>
<el-button type="primary" size="mini" @click="nextPage">下一页<i class="el-icon-arrow-right el-icon--right"></i></el-button>
</el-button-group>
<div style="marginTop: 10px; color: #409EFF;text-align: center;">{{ pageNum }} / {{ pageTotalNum }}</div>
<br>
</div>
</template>
<script>
import pdf from 'vue-pdf'
export default {
name: 'Pdf',
components: {
pdf,
},
props: {
url: {
type: String,
default: ''
},
},
data() {
return {
pageNum: 1,
pageTotalNum: 1, //总页数
loadedRatio: 0, //当前页面的加载进度,范围是0-1 ,等于1的时候代表当前页已经完全加载完成了
}
},
created() {
console.log(this.url,"pdf")
},
methods: {
// 上一页
prePage() {
let page = this.pageNum
page = page > 1 ? page - 1 : this.pageTotalNum
this.pageNum = page
document.getElementById("pdfId").scrollIntoView();
},
// 下一页
nextPage() {
//找到元素 scrollIntoView()方法让当前的元素滚动到浏览器窗口的可视区域内
let page = this.pageNum
page = page < this.pageTotalNum ? page + 1 : 1
this.pageNum = page
document.getElementById("pdfId").scrollIntoView();
}
}
}
</script>
第三步
在需要使用这个组件的.vue文件里注入进来,
注意
引入的路径是否正确,这段代码我就不贴出来了,自行写一下就可以,一共就两行。
第四步
重点:
使用pdf组件
解释
filePreviewModal:是否显示的意思,定义这么一个全局变量即可,默认为false不显示。
filePreviewUrl:文件地址。
<a @click="filePreview(record)" v-if="roleCOde=='admin'">预览</a>
<j-modal :visible='filePreviewModal' :width='1400' cancelText='关闭' switchFullscreen title="预览" @cancel="filePreviewModal = false">
<template>
<div>
<pdfView :url="filePreviewUrl" style="width: 600px;height: 900px;"></pdfView>
</div>
</template>
<template slot="footer">
<div>
<a-button type="white" @click="filePreviewModal = false">关闭</a-button>
</div>
</template>
</j-modal>
filePreviewUrl:上传文件的地址+文件名文章来源:https://www.toymoban.com/news/detail-670438.html
filePreview(record){
this.filePreviewUrl = 'http://'+record.document
this.filePreviewModal = true
},
结束语
有兴趣的博主们可以关注一下,后期会经常分享在项目开发中遇到一些新的功能以及处理的Bug会及时更新在本博主的主页中哦!!!文章来源地址https://www.toymoban.com/news/detail-670438.html
到了这里,关于vue 实现在线预览PDFpdf文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!