vue 工程pdf在线预览

本文介绍了如何在Vue项目中利用pdfjs-dist库进行PDF在线预览。首先,详细说明了安装指定版本pdfjs-dist以避免导入错误的步骤,然后讲解了如何在工程中实际应用该库进行预览。最后,提到了该方法仅支持PDF显示,不支持复制功能,但提供了支持复制功能的进一步写法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用pdfjs-dist实现vue工程pdf在线预览

1、安装(我安装的是这个版本,安装最新的版本在文件中import时会报错:You may need an appropriate loader to handle this file type)

npm install -s pdfjs-dist@2.0.943

2、使用

<template>
  <div>
    <canvas v-for="page in pages" :id="'the-canvas'+page" :key="page"></canvas>
  </div>
</template>

<script>
import PDFJS from "pdfjs-dist"

export default {
  name: "pdfPreview",
  data(){
    return {
      pdfDoc: null,
      pages: 0
    }
  },
  mounted() {
    this.showPdf()
  },
  methods: {
    showPdf: function () {
      // 请求本地文件
      // let url = '/static/player.pdf'
      // 跨域请求文件,需要走后台代理,后台需要将文件流返回前端才可在页面显示
      // let url = '/pdf/showPdf?pdfUrl=http://storage.xuetangx.com/public_assets/xuetangx/PDF/PlayerAPI_v1.0.6.pdf'
      let url = 'http://storage.xuetangx.com/public_assets/xuetangx/PDF/PlayerAPI_v1.0.6.pdf'
      this.loadFile(url)
    },
    renderPage: function (num) {
      let _this = this
      this.pdfDoc.getPage(num).then(function (page) {
        let canvas = document.getElementById('the-canvas' + num)
        let ctx = canvas.getContext('2d')
        let dpr = window.devicePixelRatio || 1.0
        let
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值