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知识库 -> pdfjs-dist -> 正文阅读

[JavaScript知识库]pdfjs-dist

版本

在这里插入图片描述
使用2.0.943无草案版本,避免高版本中的高级语法总报错问题。

npm install --save pdfjs-dist@2.0.943

使用

引入

方式一:vue写法引入

<script>
// 引入
const PDFJS = require('pdfjs-dist');
PDFJS.GlobalWorkerOptions.workerSrc = require('pdfjs-dist/build/pdf.worker.min');

export default {}
</script>

方式二:js写法引入

当初因为pdfjs_dist版本号问题没解决,就放弃了require(‘pdfjs-dist’)这种引入依赖的方式,采用了引入原生js,
在public下放置了pdfview文件夹

在这里插入图片描述
然后在index.html引入pdf.js和fabric.js
使用<%= BASE_URL %>消除开发和生产路径问题,注意<%= BASE_URL %>后不能跟/

// <script type="text/javascript" src="/pdfview/pdf.js"></script> 开发时没事,打包后路径有问题
<script type="text/javascript" src="<%= BASE_URL %>pdfview/pdf.js"></script>
<script type="text/javascript" src="<%= BASE_URL %>pdfview/fabric.js"></script>

将require写法引入改为window[]

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

功能

|——getDocument(url),获取pdf实例,返回页数和其他方法等
|——|——numPages,总页数
|——|——getPage(pageNum),获取指定页
|——|——|——getViewport(scale),返回指定缩放视图的宽高
|——|——|——render(renderContext),渲染到指定区域

根据指定pdf路径,获取pdf实例。
一般情况我们都是从后台返回文件字节流,这时可以通过window.URL.createObjectURL(blob)方式创建一个虚拟路径;
如果是后台返回base64或者前端读取文件获取的base64,可以先转成blob,再使用上述代码创建路径;

// 加载模板文件
_loadFile(url) {
  const CMAP_URL = 'https://cdn.jsdelivr.net/npm/pdfjs-dist@2.0.943/cmaps/';
  PDFJS.getDocument({url:url,cMapUrl: CMAP_URL,cMapPacked: true}).then((pdf) => {
    this.pdfDoc = pdf;
    this.page_count = this.pdfDoc.numPages;
    this.$nextTick(() => {
      this.isShow = true;
      this._renderPage(1);
    });
    this.pageNum = 1;
  });
}

// 预览渲染模板文件
    _renderPage(num) {
      this.pdfDoc.getPage(num).then((page) => {
        let canvas = document.getElementById("the-canvas" + num);
        let ctx = canvas.getContext("2d");

        let viewport = page.getViewport(this.scale);
        // 宽高单位为磅pt,渲染时直接写像素px会更清晰一点
        // 例如A4纸:595 x 841pt,但渲染时写的是595 x 841px,
        // 要是做拖拽签章功能时,注意图片单位要和PDF单位保持一致
        this.pdfHeight = canvas.height = viewport.height;
        this.pdfWidth = canvas.width = viewport.width;
        let renderContext = {
          canvasContext: ctx,
          viewport: viewport
        };
        page.render(renderContext);
        if (this.page_count > num) {
          this._renderPage(num + 1);
        }
      });
      this.page_num = this.pageNum;
    },

实例

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-24 20:47:38  更:2022-09-24 20:50:24 
 
开发: 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/11 15:46:18-

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