【CSS】---- 根据【张鑫旭-高宽不等图片固定比例布局的三重进化】的思考

前言

今天突然看到了张鑫旭大佬2023年写的《CSS高宽不等图片固定比例布局的三重进化》,从最开始的百分比padding到flex和aspect-ratio配合,最后使用container-type: inline-size和cqw配合实现,发现遇到相同的情况和我们现在实现的不同,于是就自己实现了一下。

效果

1. 基础的HTML结构

复制代码
<div class="box">
  <img src="http://image.zhangxinxu.com/image/study/s/hanyun.jpg"/>
  <img src="http://image.zhangxinxu.com/image/study/s/s512/mm1.jpg"/>
  <img src="http://image.zhangxinxu.com/image/study/s/s512/mm5.jpg"/>
  <img src="http://image.zhangxinxu.com/image/study/s/s512/mm2.jpg"/>
  <img src="http://image.zhangxinxu.com/image/study/s/s512/mm3.jpg"/>
  <img src="http://image.zhangxinxu.com/image/study/s/s512/mm4.jpg"/>
</div>

2. 使用flex实现

2.1 实现代码
复制代码
.box{
  width: 400px;
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.box img{
  width: calc(25% - 1.5rem / 4);
  aspect-ratio: 1;
  object-fit: cover;
}
  1. 可以看到在 img 的宽度时,还是需要通过 calc 函数进行计算,这里的1.5rem其实就是 gap 是 0.5rem,四张图片之间存在三个空隙,所以总宽度就是 0.5rem * 3 = 1.5rem;然后这个空隙需要四张图片来平分,所以除以 4,计算出最后宽度,高度没有进行计算,直接使用的是 aspect-ratio。

  2. 当然这里你也可以使用 container-type: inline-size和cqw 实现,只是需要将 % 换成 cqw。

    .box{
    width: 400px;
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    container-type: inline-size;
    }
    .box img{
    width: calc(25cqw - 1.5rem / 4);
    aspect-ratio: 1;
    object-fit: cover;
    }

  3. 可以到这些方法都是需要进行计算的,感觉比较麻烦,如何进行不计算,就能实现呢?我想到了 grid。

2.2 查看效果

flex 实现效果

3. 使用 grid 实现

3.1 实现代码
复制代码
.box{
  width: 400px;
  display: grid;
  gap: 0.5rem;
  grid-template-columns: repeat(4, 1fr);
}
.box img{
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}
3.2 查看效果

grid 实现效果

4. 总结

  1. 通过 CSS高宽不等图片固定比例布局的三重进化,可以看到从最开始的浮动布局使用padding,到最后的 cqw,使用的CSS代码是越来越少,实现相同的效果。
  2. 现在我们实现使用 grid 布局后,连原来计算图片的宽度都省掉,发现CSS让我们越来越方便;
  3. CSS 的进化让我想起前两天看到的一个属性,以前的瀑布流布局,需要在每天加一个元素,计算高度,但是现在直接两行CSS就能解决,不用再使用那么多JS去获取、计算、比较,可见CSS都是让我们的开发越来越简单,代码越来越简洁的。
相关推荐
夏幻灵31 分钟前
HTML5里最常用的十大标签
前端·html·html5
Mr Xu_1 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝1 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions1 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发1 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_1 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞051 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
我爱加班、、1 小时前
Websocket能携带token过去后端吗
前端·后端·websocket
AAA阿giao1 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
杨超越luckly1 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强