当前位置: 首页 > article >正文

pdf.js 预览pdf的时候发票数据缺失显示不全:字体加载出错(缺失)导致部分缺失

首先,排除后端返回的PDF文件流是没有问题的:
在这里插入图片描述

但是在vue项目中是这样的:
在这里插入图片描述
明显是显示不全,F12查看报错信息,有以下警告:

pdf.js:2153 Warning: Error during font loading: The CMap “baseUrl” parameter must be specified, ensure that the “cMapUrl” and “cMapPacked” API parameters are provided.

翻译过来就是:
pdf.js:2153警告:字体加载过程中出错:必须指定CMap“base url”参数,请确保提供cMap url”和“cMapPacked”API参数。


原因:PDF文档中包含有pdf.js不支持的字体格式。


问题找到了,就开始找关键字:cMapUrl 把字体添加进来就好

先看成果:

在这里插入图片描述

具体操作:

1 下载

下载地址:https://mozilla.github.io/pdf.js/getting_started/
在这里插入图片描述
我用的版本:pdfjs-4.8.69-dist

2 放入项目

放在static文件夹下面或者public 下面:
在这里插入图片描述
找到以下代码并注释掉:
目的是屏蔽跨域错误,允许跨域

try {
      const viewerOrigin = new URL(window.location.href).origin || "null";
      if (HOSTED_VIEWER_ORIGINS.includes(viewerOrigin)) {
        return;
      }
      const fileOrigin = new URL(file, window.location.href).origin;
      // 屏蔽跨域错误,允许跨域
      // if (fileOrigin !== viewerOrigin) {
      //   throw new Error("file origin does not match viewer's");
      // }
    } catch (ex) {
      PDFViewerApplication._documentError("pdfjs-loading-error", {
        message: ex.message
      });
      throw ex;
    }

3 使用

 <iframe id="pdf_container" :src="`/pdf/web/viewer.html?file=${encodeURIComponent(pdfUrl)}`"></iframe>

然后就可以了


http://www.kler.cn/a/415882.html

相关文章:

  • 嵌入式QT学习第4天:Qt 信号与槽
  • 命令行应用开发入门指南:从脚手架搭建到UI库与交互增强
  • Vue.js 中的事件处理
  • 二刷代码随想录第16天
  • C# 常量
  • 简释下oracle的set define的使用场景
  • qt QGraphicsPolygonItem详解
  • RVO动态避障技术方案介绍
  • 力扣--LCR 150.彩灯装饰记录II
  • 深度学习2:从零开始掌握PyTorch:数据操作不再是难题
  • 从零开发操作系统-聊一聊C语言中的头文件
  • 对于GC方面,在使用Elasticsearch时要注意什么?
  • SQL Server 实战 - 多种连接
  • 网络基础 - IP 隧道篇
  • 【Git】Git 命令参考手册
  • 定时任务删除MongoDB历史数据
  • 十四(AJAX)、AJAX、axios、常用请求方法(GET POST...)、HTTP协议、接口文档、form-serialize
  • 26届JAVA 学习日记——Day17
  • 网络安全实验环境的搭建
  • TopK算法
  • ScratchLLMStepByStep——从零一步一步构建大语言模型
  • 《Django 5 By Example》阅读笔记:p339-p358
  • 宠物领养平台开发:SpringBoot实战
  • 抓包之查看http basic auth认证方式
  • Python 【工具】 之 【Gradio】AI 模型展示工具的 安装、使用案例教程(一)
  • 【C#】lambda , lambda 表达式语法