九宫格布局解决方案

背景

还记得在以前开发小程序的时候遇到过一个样式布局问题,就是需要在一个盒子里面布局1-9个小卡片来放照片,卡片的宽高都是固定的,父盒子的宽度铺满,高度是自动。当时我是我想都不想直接flex一把嗦,想着直接搞定,但是布局效果显然在不满足9个的时候就会布局奇怪

css 复制代码
  display:flex;
  flex-wrap: wrap;
  justify-content: space-between;

这样的布局肯定是不满足我的期望的

直接上grid

css 复制代码
display: grid; 
grid-template-columns: repeat(auto-fill, 240px); 
justify-content: space-between; 
grid-row-gap: 20px; 
grid-column-gap: 20px;

现在基本上就满足布局的要求了

兼容

其实基本都还行,除了被抛弃那个浏览器0.0

css处理

scss 复制代码
  $width: 100%;
  $count: 3;
  $cellWidth: 100px;
  $margin-auto: calc((100% -  #{$count} * #{$cellWidth})/(#{$count} * 2));

.container {
  box-sizing: border-box;
  width: 375px;
  height: auto;
  background: #000;
  padding:  10px 10px;
  .fake-img {
    display:inline-block;
    width: 100px;
    height: 100px;
    background: red;
    margin: 10px $margin-auto;
  }
}

看起来是有点麻烦,基本思路就是计算盒子两边边距宽度来实现布局,维护基本难度也不大;还顺便学习了预处理器的语法,泰裤辣。

相关推荐
疯狂的沙粒14 分钟前
Vue 前端大屏做多端屏幕适配时,如何让其自动适配多种不同尺寸的屏幕?
前端·javascript·vue.js
范小多17 分钟前
24小时学会Python Visual code +Python Playwright通过谷歌浏览器取控件元素(连载、十一)
服务器·前端·python
ooolmf18 分钟前
matlab2024读取温度01
java·前端·javascript
打工人小夏19 分钟前
前端vue3项目使用nprogress动画组件,实现页面加载动画
前端
一颗宁檬不酸21 分钟前
前端农业商城中产品产地溯源功能的实现
前端
李少兄28 分钟前
深入理解前端中的透视(Perspective)
前端·css
江公望38 分钟前
HTML5 History 模式 5分钟讲清楚
前端·html·html5
云和数据.ChenGuang1 小时前
Zabbix Web 界面安装时**无法自动创建配置文件 `zabbix.conf.php`** 的问题
前端·zabbix·运维技术·数据库运维工程师·运维教程
码界奇点1 小时前
Java Web学习 第15篇jQuery万字长文详解从入门到实战解锁前端交互新境界
java·前端·学习·jquery
前端老曹1 小时前
vue3 三级路由无法缓存的终极解决方案
前端·javascript·vue.js·vue