pdfjs-dist实现pdf预览偶现空白不报错问题解决

javascript 复制代码
const calculateFitScale = (pageWidth, pageHeight) => {
  const canvas = canvasRef.value;
  if (!canvas) return 1;

  const container = document.getElementById("pdf-container");
  if (!container) return 1;

  const containerWidth = container.clientWidth;
  const containerHeight = container.clientHeight;

  if (containerWidth === 0 || containerHeight === 0) {
    return 1;
  }  // 关键代码

  // 计算适应宽度的scale
  const scaleWidth = containerWidth / pageWidth;
  //const scaleHeight = containerHeight / pageHeight;

  // 取平方根使缩放更合理(避免过度缩放)
  return Math.sqrt(scaleWidth);
  // return Math.min(scaleWidth); // 取最小值
};

问题出现情况: 在预览第一张图的时候通常都是成功的,后面的图偶尔会在cavnas中空白渲染,经排查就是初始化渲染的时候,计算适应容器的缩放比例这里出错了,关键解决代码如下:

if (containerWidth === 0 || containerHeight === 0) {

return 1;

}

读取pdf容器的宽高的时候读取到0 ,导致渲染了宽高为0的画布。

相关推荐
每天吃饭的羊7 分钟前
箭头函数(Arrow Functions)和普通函数(Regular Functions)
开发语言·javascript·ecmascript
zl_vslam12 分钟前
SLAM中的非线性优化-2D图优化之激光SLAM cartographer前端匹配(十七)
前端·人工智能·算法
寻觅~流光13 分钟前
封装---统一封装处理页面标题
开发语言·前端·javascript·vue.js·typescript·前端框架·vue
岸边的风14 分钟前
退出登录后头像还在?这个缓存问题坑过多少前端!
前端·缓存·状态模式
菜包eo16 分钟前
教育行业可以采用Html5全链路对视频进行加密?有什么优势?
前端·音视频·html5
子林super28 分钟前
Selection ES集群6月28日压测报告(7.10与7.6.2压测对比)
前端
码哥DFS30 分钟前
JS进阶-day1 作用域&解构&箭头函数
前端·javascript
月光番茄38 分钟前
基于AI的智能自动化测试系统:从Excel到双平台测试的完整解决方案
前端
凌览41 分钟前
因 GitHub 这个 31k Star 的宝藏仓库,我的开发效率 ×10
前端·javascript·后端
喝西瓜汁的兔叽Yan42 分钟前
小效果--多行文本溢出出现省略号
前端·css