处理在 electron 中使用开启了懒加载的 el-image 后,窗口最大化或窗口尺寸变化后图片无法显示的问题

1、问题描述

electron 中使用 el-image 时,开启了懒加载后,发现只有当窗口滚动后,图片才会显示,即便图片已经处于窗口的可视区域。当拖动窗口使其尺寸变大及点击窗口最大化后发现图片无法显示。

2、详情动图

详情动图

3、解决思路

由于拖拽及窗口最大化时,窗口无滚动,只好通过手动方式滚动装载图片的父级容器,该父级容器设置了 overflow: scroll;overflow-y: auto 属性,在组件挂载前滚动界面并监听 resize 事件,组件卸载后取消监听,即可修复该问题。

4、解决方案

<div id="imgs" ref="scrollContainer">
    <el-image 
    :src="info.small" 
    lazy 
    fit="contain" 
    :preview-src-list="imgPathList" 
    :initial-index="index" 
    :hide-on-click-modal="true">
        <template #error id="img_error">
            <div class="image-slot">Loading image error</div>
        </template>
    </el-image>
</div>
// 绑定图片展示主容器
const scrollContainer = ref(null);

const handleResize = () => {
    nextTick(() => {
        if (scrollContainer.value) {
            // 只需滚动 1px 即可解决,无需过多,但也不可太少
            scrollContainer.value.scrollTop += 1;
        }
    });
};

onMounted(() => {
    handleResize();
    window.addEventListener("resize", handleResize);
});

onUnmounted(() => {
    window.removeEventListener("resize", handleResize);
});

5、效果展示

通过观察dom元素结构还发现,即便手动滚动了1个像素点,依然保留了懒加载的功能,并非把所有的图片都提前加载完。

效果展示

最近更新

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

    2024-07-16 07:20:06       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-16 07:20:06       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-16 07:20:06       58 阅读
  4. Python语言-面向对象

    2024-07-16 07:20:06       69 阅读

热门阅读

  1. Web3发展的基本要素

    2024-07-16 07:20:06       30 阅读
  2. 自研electron31+vue3+elementPlus桌面聊天Exe应用-源码版

    2024-07-16 07:20:06       22 阅读
  3. 2024最新超详细SpringMvc常用注解总结

    2024-07-16 07:20:06       25 阅读
  4. 编织微服务网络:在Eureka中打造分布式服务网格

    2024-07-16 07:20:06       26 阅读
  5. 策略模式原理与C++实现

    2024-07-16 07:20:06       22 阅读
  6. 高效守护:在Eureka中构筑服务的分布式安全防线

    2024-07-16 07:20:06       25 阅读
  7. 什么是HTML?

    2024-07-16 07:20:06       24 阅读
  8. 扫地机器人的工作原理

    2024-07-16 07:20:06       21 阅读