弹性盒模型适配-y=ax+b
弹性盒模型适配-y=ax+b
ul下的li显示display:flex;
ul{
width:800px;
height:100px;
display:flex;
}
每个元素自己左浮动了,margin没有合并。
data:image/s3,"s3://crabby-images/19402/194022cd0cec4cc2897f7c8603099041b5ee6dbc" alt=""
如果把宽度该为400px,不够5个<li>看看发生什么情况?
data:image/s3,"s3://crabby-images/2458a/2458a287af8539b91ce8f4934778e7a1b80c9d08" alt=""
宽度发生了变化,高度够用所以没有变化,margin任然保持.同理,我们测试了高度
data:image/s3,"s3://crabby-images/1ec50/1ec502e65be07cb30e3bbd51772093a8cc440179" alt=""
发现高度会超出,不会自动缩小.
总结:
- display:flex;会让元素左浮动
- 如果ul设置宽度不够,会缩小子元素的宽度满足条件,有个居中的好处。
- 如果ul高度放不下li,不会缩小高度
然后我们测试一下,flex-wrap:wrap;
如果加上这句,
ul{
width: 500px;
height: 100px;
border: 3px solid #000;
margin: 0;
padding:0;
list-style: none;
background-color: gold;
margin: 50px auto;
display: flex;
flex-wrap:wrap;
}
data:image/s3,"s3://crabby-images/f8c27/f8c27795be73a14695b4fee69565c7788422bf40" alt=""
这个发现这家伙不会宽度不会缩小了,像吃了兴奋剂,宽度保持,换行。默认值是flex-wrap:no-wrap;
注意:不给高度会自动张开,以下不给高度了。
接下来看看flex-wrap:wrap-reverse;
data:image/s3,"s3://crabby-images/b5eea/b5eeae407485fcbe77956f98c7d4f6efbe59eb28" alt=""
从底部排布,一直往上.
总结:
- display:flex;可以和flex-wrap;结合使用,用来调整换行,默认不换行,压缩宽度
- flex-warp:还有wrap,wrap-reverse,reverse从底部排
- ul不给高度会自动撑开
flex-flow:可以同时设置两个值(flex-flow:flex-direction|flex-wrap)
下面看看强大的,justify-content:flex-start|flex-end|center|space-between|space-around
justify-content:start
data:image/s3,"s3://crabby-images/8fbac/8fbac2540bf7191ccb2d28e7f3d774af70caf588" alt=""
justify-content:end
data:image/s3,"s3://crabby-images/1c495/1c4955250d119e994b1447b26a0240556b6abeb5" alt=""
justify-content:center
data:image/s3,"s3://crabby-images/9452c/9452cd832cca3e437f5cb74c88430db666d9feb0" alt=""
start保持开头margin,end保持后边margin,center保持中间两倍margin,不重合。
justify-content:center
justify-content:space-around
data:image/s3,"s3://crabby-images/5492e/5492e754025d279e61825a078644288df973fc8f" alt=""
between这是两边对其顶满。
align-items:flex-start
整体偏上,当然ul设置了高度,不然就会margin都一样,但这里虽然margin不一样了,但是每个的高度都一样的。整体偏上。data:image/s3,"s3://crabby-images/c48ae/c48aeee70a2b238c524b25ff7415e0f5e86c5521" alt=""
align-items:flex-end
data:image/s3,"s3://crabby-images/45bf2/45bf27dd745c6b2ffe3f348084fa7831cd553627" alt=""
发现整体偏下
对比
align-items:center;第一排元素 的上边距,和最后一排下边距相等data:image/s3,"s3://crabby-images/d86db/d86db5db06c53fa1605792d3dd90467b6b9b06db" alt=""
data:image/s3,"s3://crabby-images/03dcb/03dcb3596fad460e4e2e40f0e87733c028f076ce" alt=""
align-items:strech
只有在高度取消时有作用
data:image/s3,"s3://crabby-images/67268/6726817961f5e3f283c375cf4ff081381d71ca5b" alt=""
align-content:start,end,center,around,between;
align-content:center,align-items:center,justify-flex:center区别??
justify-center:针对单行居中,保持中间间距
align-content:center,保持内容整体部分,间距,整体居中。但是上下左右边距不再保持。
algn-items:元素个体单体为单位,每个的间距都不在保持。
data:image/s3,"s3://crabby-images/98485/984859050c8c808d03ca4ab0663d700bc13b87b8" alt=""
grow2并不是2是1的两倍,而是增长是1的两倍。原来是50,一个增加40,一个增加80.
减少shrink也是一样。
flex-basis:初始值,从什么时候开始增加??
适配是一个y = ax + b的过程。
可以设置b
单独设置,一个的排布
ul:nth-child(2){
align-self:flex-end;
}