vue 实现在线预览PDFpdf文件

功能描述

最近在项目开发中,客户有这样一个需求:在线预览上传上去的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:上传文件的地址+文件名

filePreview(record){
    
    
       this.filePreviewUrl = 'http://'+record.document
       this.filePreviewModal = true
     },

结束语

有兴趣的博主们可以关注一下,后期会经常分享在项目开发中遇到一些新的功能以及处理的Bug会及时更新在本博主的主页中哦!!!

猜你喜欢

转载自blog.csdn.net/xiaohua616/article/details/129832628