使用vue-pdf出现的卡顿,空白,报错,浏览器崩溃解决办法

如果想直接知道解决办法,请翻到最下面

  1. 今天,接到了一个新的需求,我们公司的PDF展示卡住了,导致浏览器直接奔溃。
  2. 我也刚来公司不久,就去看看是怎么发生的,公司前同事用的vue-pdf,刚开始以为是文件太大,加载太快的问题,后面发现是vue-pdf报了一个错误。

RenderingCancelledException:Rendering cancelled, page 1

3.找到问题后,我前往github这个插件的仓库查看,在issue中发现早在三年前已经有小伙伴发现了这个bug,但是直到今天,作者大大也没有解决。

4.其中有小伙伴说可以用分页解决,可是我们公司原先用的就是分页啊,当你点击过快的时候,也会报错。

5.于是,我赶紧去找其他的解决方案,发现iframe可以嵌入展示PDF,而且原生的效果非常好,当我满怀信心,认为小case时,我发现大意了,我们公司的PDF是保密的,是不能被下载的,于是我使用 :

:src="pdfUrl + '?page=hsn#toolbar=0'"

标记了iframe的src属性,去掉了头部的下载按钮,但是紧接着发现,鼠标右键也能调出。

6.于是我换了一个思路,将div覆盖iframe,然后透明不就可以了吗,但是发现覆盖之后,页面无法滑动,此方案又被pass。

7.最后,我开始使用pdfvuer这个插件

npm i pdfvuer

8.切记使用v-for循环,不然对于大的pdf文件,还是会很卡,很影响用户体验,但至少不会崩掉

9.引入

import pdfvuer from "pdfvuer";

components: {

pdf: pdfvuer

},

javascript 复制代码
<pdf
      class="pdf"
      :src="pdfUrl"
      v-for="i in pageCount"
      :key="i"
      :page="i"
      v-if="pdfUrl"
    >
    </pdf>

10.通过方法获取总页数

javascript 复制代码
// 获取 pdf 信息
    getPdf(Url) {
      this.pdfUrl = pdfvuer.createLoadingTask(Url);
      this.pdfUrl
        .then(pdf => {
          console.log("pdf", pdf);
          this.pageCount = pdf.numPages;
          this.fullscreenLoading = false;
        })
        .catch(err => {
          console.log(err);
        });
    },

11.再添加一个element的加载状态就可以完美解决了,只不过第一次加载可能会有一些慢,但是加载之后就不会卡了

相关推荐
williamdsy35 分钟前
【Vue PDF】Vue PDF 组件初始不加载 pdfUrl 问题分析与修复
前端·javascript·vue.js·pdf
来自外太空的鱼-张小张40 分钟前
java将pdf文件转换为图片工具类
java·python·pdf
zjsx1382 小时前
2025国家卫健委减肥食谱PDF完整版(免费下载打印)
pdf·减肥·国家版减肥
SEO-狼术3 小时前
Create and Manage Content Crack
pdf
拓端研究室18 小时前
专题:2025中国游戏科技发展白皮书报告汇总解读|附130+份报告PDF汇总下载
科技·游戏·pdf
沉到海底去吧Go19 小时前
【工具教程】批量PDF识别提取区域的内容重命名,将PDF指定区域位置的内容提取出来改名的具体操作步骤
pdf·pdf识别改名·pdf区域内容改名·批量pdf识别区域内容重命名
开开心心就好19 小时前
高效账号信息管理工具,可安全随机生成密码
javascript·安全·docker·智能手机·pdf·word·excel
CodeCraft Studio1 天前
PDF处理控件Aspose.PDF教程: 在 Java 中编辑 PDF 页面大小
java·pdf·aspose·aspose.pdf
課代表1 天前
Acrobat 首选项配置:从注册表到锁定机制
pdf·注册表·路径·preference·acrobat·首选项·administrator
胡斌附体1 天前
vue父子组件通信的使用, 跟新v-model
vue·v-model·使用场景·emit·子父组件通信·change事件