要设置flexbox项目之间的最小距离,我使用margin: 0 5px on .item和margin: 0 -5px on container。对我来说,这似乎是一种hack,但我找不到更好的方法来做到这一点。
#箱{
显示:flex;
宽度:100 px;
Margin: 0 -5px;
}
.item {
背景:灰色;
宽度:50 px;
高度:50 px;
边距:0 5px;
}
< div id =“盒子”>
< div class = '物品' > < / div >
< div class = '物品' > < / div >
< div class = '物品' > < / div >
< div class = '物品' > < / div >
< / div >
假设:
你想要4列网格布局与包装
项目的数量不一定是4的倍数
除了第1、5、9项以外,每项都设置左距;并在每个项目上设置固定宽度。如果左边的边距是10px,那么每行4个项目之间的边距是30px,项目宽度的百分比可以计算如下:
100% / 4 - horizontal-border - horizontal-padding - left-margin * (4 - 1) / 4
这是一个体面的工作,涉及flexbox最后一行的问题。
.flex {
显示:flex;
flex-direction:行;
flex-wrap:包装;
保证金:1em 0;
background - color:桃色;
}
.item {
margin-left: 10 px;
边框:1px实体;
填充:10 px;
宽度:calc(100% / 4 - 2px - 20px - 10px * (4 - 1) / 4);
background - color:番木瓜;
}
.item:n -child(4n + 1) {
margin-left: 0;
}
.item:n -child(n + 5) {
margin-top: 10 px;
}
flex < div class = " " >
< div class = "项目" > < / div > 1
< div class = "项目" > < / div > 2
< div class = "项目" > 3 < / div >
4 < div class = "项目" > < / div >
< / div >
flex < div class = " " >
< div class = "项目" > < / div > 1
< div class = "项目" > < / div > 2
< div class = "项目" > 3 < / div >
4 < div class = "项目" > < / div >
5 < div class = "项目" > < / div >
< div class = "项目" > < / div > 6
< / div >
flex < div class = " " >
< div class = "项目" > < / div > 1
< div class = "项目" > < / div > 2
< div class = "项目" > 3 < / div >
4 < div class = "项目" > < / div >
5 < div class = "项目" > < / div >
< div class = "项目" > < / div > 6
< div class = "项目" > < / div > 7
< div class = "项目" > < / div > 8
< div class = "项目" > < / div > 9
< / div >
嗯,在我看来,关于CSS最简单的解决方案,
是在HTML中添加间隔符:
<div id='box'>
<div class='item'></div>
<div style='width: 5px;'></div>
<div class='item'></div>
<div class='item'></div>
<div class='item'></div>
</div>
所以,你可以用内联风格或类名来控制它。
有时候,也可以用填充来做间距。
下面是一个例子
好吧,现在你有一个缺口,所以你可以使用它,但好的ol技术仍然是不可避免的,像<div><div></div></div>包装构造独特的项目与独特的缺口(使用填充物为缺口!和ofc新的gap属性)