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

文章目录

1、问题描述

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

2、详情动图

3、解决思路

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

4、解决方案

html 复制代码
<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>
js 复制代码
// 绑定图片展示主容器
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个像素点,依然保留了懒加载的功能,并非把所有的图片都提前加载完。

相关推荐
2501_924064111 分钟前
2025年主流Web自动化测试工具功能与适用场景对比
前端·测试工具·自动化
polarislove02143 分钟前
9.5 [定时器]输入捕获-嵌入式铁头山羊STM32笔记
笔记·stm32·嵌入式硬件
童话名剑3 分钟前
Inception网络(吴恩达深度学习笔记)
网络·笔记·深度学习
IT_陈寒15 分钟前
Vite 5 实战:7个鲜为人知的配置技巧让构建速度提升200%
前端·人工智能·后端
gg1593572846015 分钟前
JavaScript 核心基础
前端·javascript·vue.js
深蓝海拓18 分钟前
PySide6从0开始学习的笔记(二十一) 使用loadUi直接加载.ui文件
笔记·python·qt·学习·ui·pyqt
charlie11451419121 分钟前
FreeRTOS: 信号量(Semaphores)、互斥量(Mutex)与优先级继承
开发语言·笔记·学习·c·freertos·实时操作系统
Stanford_110630 分钟前
【2026新年启程】学习之路,探索之路,技术之路,成长之路……都与你同行!!!
前端·c++·学习·微信小程序·排序算法·微信开放平台
Ahtacca36 分钟前
Redis 五大常用数据类型详解及 Java 客户端(RedisTemplate)操作实战
java·数据库·redis·学习·缓存
打小就很皮...38 分钟前
网页包装为桌面应用(Nativefier版)
前端·桌面应用·nativefier