码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 使用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

      },

    1. class="pdf"
    2. :src="pdfUrl"
    3. v-for="i in pageCount"
    4. :key="i"
    5. :page="i"
    6. v-if="pdfUrl"
    7. >

    10.通过方法获取总页数

    1. // 获取 pdf 信息
    2. getPdf(Url) {
    3. this.pdfUrl = pdfvuer.createLoadingTask(Url);
    4. this.pdfUrl
    5. .then(pdf => {
    6. console.log("pdf", pdf);
    7. this.pageCount = pdf.numPages;
    8. this.fullscreenLoading = false;
    9. })
    10. .catch(err => {
    11. console.log(err);
    12. });
    13. },

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

  • 相关阅读:
    【vue3】07. 跟着官网学习vue3
    Java基础 - 模拟医院挂号系统
    什么是Vue.js的响应式系统(reactivity system)?如何实现数据的双向绑定?
    TFT-LCD屏幕读取Flash芯片图片资源并显示
    基于截止至 2023 年 5 月 30 日,在 App Store 上进行交易的设备数据统计,iOS/iPadOS 各版本更新情况
    HTML基础--Form表单--内联元素
    视频转gif怎样操作?1分钟在线视频转gif制作
    如何使用Python和Numpy实现简单的2D FDTD仿真:详细指南与完整代码示例
    Bun 发布 1.0 正式版本,Zig 编写的 JavaScript 运行时
    [Display嵌入式]SDL播放 mjpeg 檔案到屏幕上
  • 原文地址:https://blog.csdn.net/CHENC0518/article/details/132609270
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号