背景
还记得在以前开发小程序的时候遇到过一个样式布局问题,就是需要在一个盒子里面布局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;
}
}
看起来是有点麻烦,基本思路就是计算盒子两边边距宽度来实现布局,维护基本难度也不大;还顺便学习了预处理器的语法,泰裤辣。