pdf预览空白问题解决。第一次预览正常,再重新打开就空白的问题。是因为cmaps没有更新

问题描述

我用的是pdfjs作为PDF预览工具使用。

预览有电子签章的PDF后(如下图的水印、签章),再重新预览没有电子签章的PDF,就会空白。

image-20240409180826135

image-20240409180734930

image-20240409175713002

如上图,第一个PDF的接口加载了电子签章的字体,但是当我点击第二个PDF时,就出现预览空白,原因是因为它沿用了前面PDFcmaps文件。

看网络面板,可以排除是接口的问题,因为在预览PDF时,是重新获取了PDF文件流的。

image-20240409180023310

所以,问题就出在重新加载新的PDF文件流时,有缓存,没有更新bcmaps文件导致。

问题解决

最开始我尝试用特殊的方法去解决bcmaps缓存的问题,但是都无效。

包括问了各个AI,也无济于事。

后面我发现用这些预览时,其实都是用的是同一个组件。

所以,就应该销毁PDF预览组件,让其第二次打开时,重新构建,不依赖之前的缓存即可。

最终添加了一行很简单的代码来解决了。

<el-dialog
      width="80%"
      title="文件预览"
      v-loading="loading"
      :visible.sync="dialogPdfViewVisible"
      append-to-body
    >
      <pdf-view
        v-if="dialogPdfViewVisible"  //这里就是我添加的  v-if即可
        :pdf-data="pdfViewData"
        data-type="base64"
        :total="true"
        :visible="true"
        custom-class="canvasdiffer"
      />
    </el-dialog>

问题总结

出了问题,如果能通过刷新页面就能解决问题,那么就是缓存问题。想办法让其不缓存即可解决。

曾经参考过的文章(也未能解决)

https://blog.csdn.net/weixin_42530606/article/details/136152608

https://blog.csdn.net/weixin_44998124/article/details/120889121

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-10 12:10:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-10 12:10:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-10 12:10:01       82 阅读
  4. Python语言-面向对象

    2024-04-10 12:10:01       91 阅读

热门阅读

  1. NPM常用命令及详解

    2024-04-10 12:10:01       29 阅读
  2. 用ChatGPT4.0生成美观的PDF

    2024-04-10 12:10:01       32 阅读
  3. C. Omkar and Baseball Codeforces Round 655 (Div. 2)

    2024-04-10 12:10:01       34 阅读
  4. codeforces round 932 div2(a,b,c)

    2024-04-10 12:10:01       33 阅读
  5. 数据资产概念解释

    2024-04-10 12:10:01       27 阅读
  6. C:获取文件大小的两种方式

    2024-04-10 12:10:01       32 阅读
  7. apex0.1版本安装踩坑指南

    2024-04-10 12:10:01       34 阅读
  8. 新媒体运营到底是什么?

    2024-04-10 12:10:01       41 阅读
  9. 列表滚动单条案例

    2024-04-10 12:10:01       41 阅读