vue

vue + pdfjs-dist 实现pdf流文件在线预览

2019-08-16  本文已影响0人  cca1000

template模板

<div class="center">
    <div class="contor">
      <el-button @click="prev">上一页</el-button>
      <el-button @click="next">下一页</el-button>
      <span>Page: <span v-text="page_num"/> / <span v-text="page_count"/></span>
      <el-button icon="el-icon-plus" @click="addscale"/>
      <el-button icon="el-icon-minus" @click="minus"/>
    </div>
    <canvas id="the-canvas" class="canvasstyle"/>
  </div>

下面引入依赖,用require吧。之前用import 一直找不到文件;
引入之前记得现在你的工程里下载插件;
npm install pdfjs-dist --save;

let PDFJS = require('pdfjs-dist');
PDFJS.GlobalWorkerOptions.workerSrc = require('pdfjs-dist/build/pdf.worker.min');

data () {
    return {
      pdfUrl: '',// 这里是pdf文件地址,后台给的流文件请求地址也是可以的
      pdfDoc: null,// pdfjs 生成的对象
      pageNum: 1,//
      pageRendering: false,
      pageNumPending: null,
      scale: 1.2,// 放大倍数
      page_num: 0,// 当前页数
      page_count: 0,// 总页数
      maxscale: 2,// 最大放大倍数
      minscale: 0.8// 最小放大倍数
    }
  },
computed: {
  ctx() {
    const id = document.getElementById('the-canvas')
    return id.getContext('2d')
  }
},
methods: {
    init () {
      let _this = this;
      // 初始化pdf
      PDFJS.getDocument(this.pdfUrl).then(function(pdfDoc_) {
        _this.pdfDoc = pdfDoc_
        _this.page_count = _this.pdfDoc.numPages
        _this.renderPage(_this.pageNum)
      })
    },
    renderPage(num) { // 渲染pdf
      const vm = this
      this.pageRendering = true
      const canvas = document.getElementById('the-canvas')
      // Using promise to fetch the page
      this.pdfDoc.getPage(num).then(function(page) {
        var viewport = page.getViewport(vm.scale)
        // alert(vm.canvas.height)
        canvas.height = viewport.height
        vm.pdfWidth = canvas.width = viewport.width
        // Render PDF page into canvas context
        var renderContext = {
          canvasContext: vm.ctx,
          viewport: viewport
        }
        var renderTask = page.render(renderContext)
        // Wait for rendering to finish
        renderTask.promise.then(function() {
          vm.pageRendering = false
          if (vm.pageNumPending !== null) {
          // New page rendering is pending
            vm.renderPage(vm.pageNumPending)
            vm.pageNumPending = null
          }
        })
      })
      vm.page_num = vm.pageNum
    },
    addscale() { // 放大
      if (this.scale >= this.maxscale) {
        return
      }
      this.scale += 0.1
      this.queueRenderPage(this.pageNum)
    },
    minus() { // 缩小
      if (this.scale <= this.minscale) {
        return
      }
      this.scale -= 0.1
      this.queueRenderPage(this.pageNum)
    },
    prev() { // 上一页
      const vm = this
      if (vm.pageNum <= 1) {
        return
      }
      vm.pageNum--
      vm.queueRenderPage(vm.pageNum)
    },
    next() { // 下一页
      const vm = this
      if (vm.pageNum >= vm.page_count) {
        return
      }
      vm.pageNum++
      vm.queueRenderPage(vm.pageNum)
    },
    queueRenderPage(num) {
      if (this.pageRendering) {
        this.pageNumPending = num
      } else {
        this.renderPage(num)
      }
    }
  }
上一篇下一篇

猜你喜欢

热点阅读