css 图片未加载时默认高度,加载后随图片高度

需求:图片宽度显示为100%,在图片未加载前需要预设高度,防止图片加载完后内容蹦极。而图片高度会随着不同分辨率所变化,无法设置固定的预设高度。

一、模拟当前情况:

1.编码

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="styles.css">
    <title>图片显示</title>
    <style>
        .container {
            width: 100%;
            display: flex;
            justify-content: center;
        }
        .content {
            width: 100%;
        }
        .title {
            font-size: 24px;
            font-weight: bold;
            margin-bottom: 20px;
        }
        .image {
            display: block;
            width: 100%;
        }

    </style>
</head>

<body>
    <div class="container">
        <div class="content">
            <p class="title">图片1</p>
            <img src="" class="image">
            <p class="title">图片2</p>
            <img src="" class="image">
            <p class="title">图片3</p>
            <img src="" class="image">
            <p class="title">图片4</p>
            <img src="" class="image">
            <p class="title">图片5</p>
            <img src="" class="image">
        </div>
    </div>
    <script>
        // 5秒后执行
        setTimeout(() => {
            let i = 0;
            const imageSrcs = [
                "https://i-blog.csdnimg.cn/direct/436796c8bd264b359b39c769310c9cde.jpeg",
                "https://i-blog.csdnimg.cn/direct/d7147f78e2bb4035bd6b81353baf047f.jpeg",
                "https://i-blog.csdnimg.cn/direct/777d089209f64ece8b96f127b08e443d.jpeg",
                "https://i-blog.csdnimg.cn/direct/1f148d411b5e4d70868e4d72562db076.jpeg",
                "https://i-blog.csdnimg.cn/direct/cf5755e2186a438383e8b2235dc812c0.jpeg"];
            const images = document.querySelectorAll(".image");
            images.forEach(image => {
                // 设置src的值
                image.src = imageSrcs[i];
                i = i + 1;
            });
        }, 5000);
    </script>
</body>
</html>

2.图片加载前

图片未加载时因无预设高度聚集堆叠,加载完成后布局瞬间撑开(类似 "蹦极" 效果)

3.图片加载后

二、优化

1.原理

给图片添加min-height属性,值为不同分辨率下图片实际高度的70%。

2.CSS编码

html 复制代码
<style>
        .container {
            width: 100%;
            display: flex;
            justify-content: center;
        }
        .content {
            width: 100%;
        }
        .title {
            font-size: 24px;
            font-weight: bold;
            margin-bottom: 20px;
        }
        .image {
            display: block;
            width: 100%;
        }
        /** 笔记本:宽度大于等于1366px时,图片高度设置为70%实际高度 **/
        @media (min-width:1366px) {
            .image1 {
                /** 图片:1:宽1366px下,实际高度为2533px,这里设置70% **/
                min-height: calc(2533px * 0.7);
            }
            .image2 {
                /** 图片:2:宽1366px下,实际高度为1638px,这里设置70% **/
                min-height: calc(1638px * 0.7);
            }
            .image3 {
                /** 图片:3:宽1366px下,实际高度为2533px,这里设置70% **/
                min-height: calc(2533px * 0.7);
            }
            .image4 {
                /** 图片:4:宽1366px下,实际高度为2066px,这里设置70% **/
                min-height: calc(2066px * 0.7);
            }
            .image5 {
                /** 图片:5:宽1366px下,实际高度为2365px,这里设置70% **/
                min-height: calc(2365px * 0.7);
            }
        }
        /** 平板:宽度大于等于800px时,图片高度设置为70%实际高度 **/
        @media (min-width:800px) {
            .image1 {
                /** 图片:1:宽1366px下,实际高度为1459px,这里设置70% **/
                min-height: calc(1459px * 0.7);
            }
            .image2 {
                /** 图片:2:宽1366px下,实际高度为943px,这里设置70% **/
                min-height: calc(943px * 0.7);
            }
            .image3 {
                /** 图片:3:宽1366px下,实际高度为1459px,这里设置70% **/
                min-height: calc(1459px * 0.7);
            }
            .image4 {
                /** 图片:4:宽1366px下,实际高度为1190px,这里设置70% **/
                min-height: calc(1190px * 0.7);
            }
            .image5 {
                /** 图片:5:宽1366px下,实际高度为1362px,这里设置70% **/
                min-height: calc(1362px * 0.7);
            }
        }
        /** 手机:宽度小于等于200px时,图片高度设置为70%实际高度 **/
        @media (min-width:200px) {
            .image1 {
                /** 图片:1:宽1366px下,实际高度为349px,这里设置70% **/
                min-height: calc(349px * 0.7);
            }
            .image2 {
                /** 图片:2:宽1366px下,实际高度为225px,这里设置70% **/
                min-height: calc(225px * 0.7);
            }
            .image3 {
                /** 图片:3:宽1366px下,实际高度为349px,这里设置70% **/
                min-height: calc(349px * 0.7);
            }
            .image4 {
                /** 图片:4:宽1366px下,实际高度为284px,这里设置70% **/
                min-height: calc(284px * 0.7);
            }
            .image5 {
                /** 图片:5:宽1366px下,实际高度为326px,这里设置70% **/
                min-height: calc(326px * 0.7);
            }
        }
    </style>

3.图片加载前

4.图片加载后

相关推荐
xiaoliuliu123452 小时前
Android Studio 2025 安装教程:详细步骤+自定义安装路径+SDK配置(附桌面快捷方式创建)
java·前端·数据库
紫_龙2 小时前
最新版vue3+TypeScript开发入门到实战教程之Pinia详解
前端·javascript·typescript
533_2 小时前
[echarts] 使用scss变量
前端·echarts·scss
老前端的功夫2 小时前
【Java从入门到入土】21:List三剑客:ArrayList、LinkedList、Vector的爱恨情仇
java·javascript·网络·python·list
小李云雾2 小时前
零基础-从ESS6基础到前后端联通实战
前端·python·okhttp·中间件·eclipse·html·fastapi
SAP小崔说事儿2 小时前
SAP B1 批量应用用户界面配置模板
java·前端·ui·sap·b1·无锡sap
Amos_Web2 小时前
Rspack 源码解析 (1) —— 架构总览:从 Node.js 到 Rust 的跨界之旅
前端·rust·node.js
qq_406176142 小时前
React 组件传参 & 路由跳转传参
前端·javascript·react.js
电商API&Tina2 小时前
唯品会数据采集API接口||电商API数据采集
java·javascript·数据库·python·sql·json