前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >vue-pdf使用demo

vue-pdf使用demo

作者头像
李维亮
发布2022-11-07 15:45:47
4090
发布2022-11-07 15:45:47
举报
文章被收录于专栏:李维亮的博客李维亮的博客
代码语言:javascript
复制
<template>
  <div class="moduleIntro">
    <el-button-group>
      <el-button type="primary" icon="el-icon-arrow-left" size="small" @click="prePage">上一页</el-button>
      <el-button type="primary" size="small" @click="nextPage">下一页<i class="el-icon-arrow-right el-icon--right"></i></el-button>
    </el-button-group>
    <div style="margin-top: 10px; color: #409EFF; text-align: center">{{ currentPage }} / {{ pageCountNum }}</div>
    <pdf
      :page="currentPage"
      :src="pdfUrl"
      @progress="loadedRatio = $event"
      @num-pages="pageCountNum = $event"
    ></pdf>
  </div>
</template>
<script>
import pdf from 'vue-pdf'
export default {
  name: 'moduleIntro',
  components: {
    pdf
  },
  data(){
    return{
      currentPage: 1,
      pageCountNum: 0, //# 总页数
      loadedRatio: 0, //# 当前页面的加载进度,范围是0-1 ,等于1的时候代表当前页已经完全加载完成了
      pdfUrl:'http://mozilla.github.io/pdf.js/web/compressed.tracemonkey-pldi-09.pdf',
    }
  },
  methods:{
    // 上一页
    prePage() {
      let page = this.currentPage
      page = page > 1 ? page - 1 : this.pageCountNum
      this.currentPage = page
    },

    // 下一页
    nextPage() {
      let page = this.currentPage
      page = page < this.pageCountNum ? page + 1 : 1
      this.currentPage = page
    }
  }
}
</script>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-10-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档