IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 【vue】pdf转图片 -> 正文阅读

[JavaScript知识库]【vue】pdf转图片

把pdf转成图片进行显示

最近做了一个需求–在html页面展示PDF文档
遇到的问题:在浏览器上可以用iframe正常打开pdf文件。但是当html嵌套在手机app里面的时候,-iframe嵌套的PDF文件就不能正常展示了。

解决办法:
1.尝试过使用安卓方法进行文件下载之后,打开PDF文件(这个方法只能在新页面打开PDF文件),但我需要在原有的页面进行PDF文档显示。
2.优化–pdf转图片显示,满足当前页面参考文档,且转为图片后暂时没有模糊等其他问题(采用)

pdf-dist使用步骤

1、下载pdf-dist包,放在public文件下面,在页面中引用方法使用(https://gitee.com/mirrors/pdfjs-dist/)
2、安装pdf-dist(npm i pdf-dist)
3、在对应的页面中引用pdf-dist

import * as PDFJS from "pdfjs-dist";

4、初始化pdf插件

/*
** @param fileUrl pdf有效的查看地址
**				(1、线上地址(如:http://www.xxx.com) 
**				2、本地public地址(例如:/static/view.pdf))
** @param  pdfPicturePath pdf转化的图片地址-用于放大查看所有pdf图片
*/
  readPdf(fileUrl) { 
    let self = this
    self.pdfPicturePath = []
    const loadingTask = PDFJS.getDocument(fileUrl);
    loadingTask.promise.then(function (pdf) {
      if (pdf) {
        // pdf 总页数
        const pageNum = pdf.numPages;
        for (let i = 1; i <= pageNum; i++) {
          // 生成每页 pdf 的 canvas
          const canvas = document.createElement('canvas');
          canvas.id = "pageNum" + i;
          // 将 canvas 添加到 dom 中,docView(存放canvas的div)
          (self.$refs as any).docView.append(canvas);
          //getContext() 方法返回一个用于在画布上绘图的环境。
          const context = canvas.getContext('2d');
          self.openPage(pdf, i, context);
        }
        setTimeout(() => {
            self.exportImg(self)
        }, 1000);
      }
    }).catch(function (reason) {
        console.error("Error: " + reason);
    });
      // };
  }

5、pdf转成canvas

/*
** @param loading pdf生成图片时的加载状态
** @param scale 控制 canvas显示的大小
** @param  pdfPicturePath pdf转化的图片地址-用于放大查看所有pdf图片
*/
  openPage(pdfFile, pageNumber, context) {
    let scale = 2;
    let that = this
    pdfFile.getPage(pageNumber).then(function (page) {
      // reference canvas via context
      const viewport = page.getViewport(scale);
      let canvas = context.canvas;
      canvas.width = viewport.width;
      canvas.height = viewport.height;
      canvas.style.width = "100%";
      canvas.style.height = "100%";
      let renderContext = {
          canvasContext: context,
          viewport: viewport
      };
      page.render(renderContext);
      that.loading = false
    });
    return;
  }

6、canvas转成图片(可根据具体情况,进行图片转化显示)
这里我把所有图片的base64存放在数组里面,方便放大查看,也可以直接把生成图片标签进行图片展示

// 转图片
  exportImg(self) {
    let canvaslist: any = document.querySelectorAll('canvas');
    for (let i = 0; i < canvaslist.length; i++) {
      // let canvas = document.getElementById("pageNum" + (i + 1));
      // // 将 canvas 转成 base64 格式的图片
      // let base64ImgSrc = (canvas as any).toDataURL("image/png")
      // const img = document.createElement("img")
      // img.setAttribute('class', 'pdf-img');
      // img.src = base64ImgSrc
      // img.style.width = '100%';
      // // 将图片挂载到 dom 中
      //   (self.$refs as any).docView.append(img);
      let canvasNode = document.getElementById("pageNum" + (i + 1));
      // 将 canvas 转成 base64 格式的图片
      this.pdfPicturePath.push((canvasNode as any).toDataURL("image/png"))
    }
  }

踩坑

1、控制台报GlobalWorkerOptions of undefined

'GlobalWorkerOptions' of undefined

解决方法:下载指定版本的pdf-dist依赖,pdf-dist@2.2.228(测试有效)

2、GlobalWorkerOptions.workerSrc of undefined

解决办法:
1、找到node_modules>_pdfjs-dist@2.2.228@pdfjs-dist>build>pdf.js文件,把GlobalWorkerOprions.workerSrc的undefined更改为./pdf.worker.js的路径
2、页面中更改

import * as  pdfjsLib from 'pdfjs-dist'
import pdfjsWorker from 'pdfjs-dist/build/pdf.worker.entry'
初始化PDF插件方法里面加上这个,手动赋值workerSrc 地址
pdfjsLib.GlobalWorkerOptions.workerSrc = pdfjsWorker;
  • 参考文章地址:https://www.cnblogs.com/wx1993/p/12533899.html
  • 参考文章地址:https://blog.csdn.net/JaneLittle/article/details/107033764
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-18 15:53:03  更:2021-12-18 15:55:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 23:46:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码