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的画布。

相关推荐
天蓝色的鱼鱼18 分钟前
前端实战:精准还原用户阅读位置的三大方案
前端·javascript
李永宁36 分钟前
AI 编辑器 + MCP 轻松实现设计稿生成前端代码
前端·mcp·trae
江城开朗的豌豆43 分钟前
Vue的隐形魔法:虚拟DOM和Diff算法如何让页面飞起来?
前端·javascript·vue.js
江城开朗的豌豆1 小时前
Vue中key值的秘密:为什么这个小东西能让列表渲染更聪明?
前端·javascript·vue.js
tager1 小时前
为什么推荐使用Whistle而不是Fiddler、Charles!🤗
前端·fiddler·charles
江城开朗的豌豆1 小时前
Vue 3.0真香!用了半年后我来告诉你为什么这么爽
前端·javascript·vue.js
前端工作日常1 小时前
我理解的 npm 作用域包
前端
小小小小宇1 小时前
移动端软键盘弹出问题
前端
小小小小宇1 小时前
前端常见浏览器兼容性问题
前端
小小小小宇8 小时前
前端并发控制管理
前端