首先情况如下(图.1)
![](https://img-blog.csdnimg.cn/9b6c0ddaf7f849b290231f99c56845ea.png)
我们最终想要的效果应是既需 平均分布 又需 最后一排 依次从左向右排列
第一种方式:
外层容器给弹性盒子布局 且给外层盒子一个 after 伪类元素
.wrap{
width: 200px;
height: 200px;
display: flex;
// 换行展示
flex-wrap: wrap;
// 首个元素放置于起点 末尾元素放置于终点
justify-content: space-between;
}
// 此处可理解为以伪元素进行占位
.wrap::after{
content: "";
width: 60px;
}
![](https://img-blog.csdnimg.cn/628e2ea114ff41cfbc0ff735bd7f28c5.png)
但是
当每行出现多于三个元素时 就会出现如下情况 (图.2)
而此情况则需另寻他路 即
第二种方式:
使用 Grid布局 (号称地表最强的CSS布局方案)
.wrap{
display: grid;
width: 200px;
height: 200px;
margin: 50px auto;
justify-content: space-between;
// 划分列 功能函数关键字 repeat (auto-fill,45px)
// 根据子元素的盒子的份额自动计算可以平铺几次
grid-template-columns: repeat(auto-fill,45px);
// grid-gap 是 row-gap 和 column-gap 的简写。
grid-gap: 0 1px;
}
![](https://img-blog.csdnimg.cn/5107744ea8cb4057a6c23f8217d01e67.png)
最后
总结下 flex布局和Grid布局的区别
首先flex 是复合属性 是添加给子元素的
那咱们先来看flex 中的各个参数:
- flex-grow 属性定义项目的放大比例 默认为0 即如果存在剩余空间 也不放大
- flex-shrink 属性定义了项目的缩小比例 默认为1 即如果空间不足 该项目将缩小
- flex-basis 属性定义了在分配多余空间之前 项目占据的主轴空间(相当于我们设置的width)
默认值为: flex:0 1 auto;(默认不放大 放不下了缩小 优先采用自己本身宽度)
flex:1 1 0%; 有剩余空间就放大,空间不够就缩小,项目长度为0
<div class="wrap">
<div class="box">夙愿</div>
<div class="box">夙源</div>
<div class="box">夙远</div>
</div>
.wrap{
height: 100px;
display: flex;
}
.box{
border: 2px solid yellowgreen;
flex: 1;
}
flexed:auto
flex:1 1 auto;有剩余空间就放大,空间不够就缩小,项目长度为原本的长度
<div class="wrap">
<div class="box">夙愿</div>
<div class="box">夙源</div>
<div class="box">夙远</div>
</div>
.wrap{
height: 100px;
display: flex;
}
.box{
border: 2px solid yellowgreen;
flex: auto;
}
由此可见
flex:1 和 flex:auto 的区别主要是在于 flex-basis
flex:1 无论内容多少,一般都是平分空间,空间大小一致
而 flex:auto 则根据内容的大小来分,而非平的(只有内容一样,才会平分)