flex盒子里面元素linehight对高度的影响
那天,高高兴兴的测试flex属性。大家都知道,当父盒子display:flex的时候,子盒子即使宽高和大于父盒子,也会由于flex的特性进行收缩;然而,在给父盒子加了flex-direction:column之后,居然出现了:

它们没收缩!!!!!!
html:
<div class="father">
<div class="box1">1</div>
<div class="box2">2</div>
<div class="box3">3</div>
<div class="box4">4</div>
</div>
css(没加flex-direction:column):
.father{
width: 300px;
height: 300px;
background-color: pink;
display: flex;
margin: 100px auto;
}
.box1,.box2,.box3,.box4{
width: 100px;
height: 100px;
line-height: 100px;
text-align: center;
}
.box1{
background-color: red;
}
.box2{
background-color: yellow;
}
.box3{
background-color: green;
}
.box4{
background-color: purple;
}
再三测试,发现是行高的影响
又再三测试,总结出来了一些规律
在竖直方向上
a.当盒子的行高和大于等于父盒子时候,行高最大的盒子的行高
1.大于等于自身设定的高度,则高度为设定的高度;剩下的父盒子高度则为父盒子原高度减去子盒子的高度;然后再其他盒子进行判断。
2.小于自身设定的高度,则高度为行高
b.当盒子的行高和小于父盒子的时候,行高最大的盒子的行高
1.大于等于父盒子高/盒子个数且大于盒子设定的高度时,则该盒子高度为设定的高度,剩下的父盒子高度则为父盒子原高度减去子盒子的高度;然后再其他盒子进行判断
2.大于等于父盒子高/盒子个数且小于盒子设定的高度时,则该盒子的高度为行高,剩下的父盒子高度则为父盒子原高度减去子盒子的高度;然后再其他盒子进行判断。
3.小于父盒子高/盒子个数且小于盒子设定的高度时,则盒子们均分剩下的高度;
如1:父盒高为300px,四个子盒子高为100px;行高分别设为120px,100px,45px,45px;总行高为120+100+45+45=310>300
则:盒子1行高大于等于自身设定的高度(120>100),走a1路线,盒子1高度将为100px;父盒子剩下高度为300-100=200px;
剩下三个盒子总行高为100+45+45=190<200px,父盒子高度/盒子个数=200/3 = 66px
则盒子2行高大于等于自身设定的高度(100>=100),走b1路线,盒子2 高度将为100px;父盒子剩下的高度为200-100=100px
剩下两个盒子总行高为45+45=90<100px 父盒子高度/盒子个数=100/2=50px
则盒子3,盒子4,均不符合行高小于父盒子高度/盒子个数(45<50),走b3路线,均分剩下的100px;每份50px;
最终结果将如下

如2:父盒高为300px,四个子盒子高为100px;行高分别设为80px,80px,80px,70px;总行高为80+80+80+70=310>300px;
则:盒子1,2,3行高小于自身设定的高度(80<100),走a2路线,盒子1,2,3高度将为80px;父盒子剩下高度为300-240=60px;
剩下盒子总行高为70px>60px,
盒子4行高小于自身设定的高度(70<100),走a2路线,盒子4高度将为行高即60px,最候结果如下:

如3:父盒高为300px,四个子盒子高为100px;行高分别设为57px,120px,30px,90px;总行高为57+120+30+90=297<300px;
则:盒子2行高大于等于自身设定的高度(120>100),走b1路线,盒子1高度将为100px;父盒子剩下高度为300-100=200px;
剩下三个盒子总行高为57+30+90=177<200px,父盒子高度/盒子个数=200/3 = 66px;
则盒子4大于等于父盒子高/盒子个数且小于盒子设定的高度(100>90>66),走b2路线,盒子2 高度将为行高90px;父盒子剩下的高度为200-90=110px
剩下两个盒子总行高为57+30=87<110px,父盒子高/盒子个数=100/2=50px
则盒子1大于等于父盒子高/盒子个数且小于盒子设定的高度(100>57>50),走b2路线,盒子1 高度将为行高57px;父盒子剩下的高度为110-57=53px
剩下的盒子30<57/1,走b3路线,53分给盒子3
最终结果为 57px,100px 53px,90px;如图

基本验证无误,欢迎大家测试。实际布局中应该尽量避免大数值的行高设置。(其实这个测试很无聊)
flex盒子里面元素linehight对高度的影响的更多相关文章
- flex盒子布局
看过很多对于弹性盒子flex的简介,但还是觉得阮一峰大神的解析和张鑫旭大神(旧版flex)的解析比较容易理解,下面,我以自己的理解来叙述关于flex弹性布局! 1.概念(容器和项目) 在flex中,有 ...
- 【css3网页布局】flex盒子模型
1.0 前言 网页布局(layout)是CSS的一个重点应用. 经典布局类型: 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊 ...
- HTML连载39-外边距合并现象、盒子模型以及宽度和高度
一. 在默认布局的垂直方向上,默认情况下外边距是是不会叠加的,会出现合并现象,谁的外边距较大,就听谁的:但是在水平方向就不会出现这种状况,我们举个例子 span{ display: inline-bl ...
- 如何让 height:100%; 起作用---父级元素必须设定高度
参考: http://www.webhek.com/post/css-100-percent-height.html https://www.cnblogs.com/kunmomo/p/1060066 ...
- BUG 图片元素img下 高度超出 出现多余空白
BUG 图片元素img下 高度超出 出现多余空白 1.将图片转换为块级对象 即,设置img为“display:block;”. 2.设置图片的垂直对齐方式 即设置图片的vertical-align ...
- jquery获取元素与屏幕高度距离
a. onscroll事件 scroll是css样式中overflow的一个值,意思是显示滚动条;当一个元素的实际高度超过他的最大高度是,只要设置了overflow为scroll b. $(..).s ...
- CSS中为什么有的元素能够设置高度,而有的元素却不能设置高度与宽度?
可以使用{display:block}将内联元素变为块级元素,同时使用{display:inline}将块级元素变为内联元素. {display:inline-block}又是怎么回事,根据张鑫旭老师 ...
- flex布局 justify-content:space-between; 解决最后一排数量不够自动向两端排列问题和flex布局的元素会有默认间隙(垂直间隙)
1 .flex 布局两端对齐当最后一排数量不够时,会出现以下布局情况 实现效果: 解决方案:使用after伪类, 解决最后一排数量不够两端分布的情况.宽度就是每张图片的宽度 .list:after { ...
- iview Carousel 轮播图自适应宽高;iview 轮播图 图片重叠问题;iview tabs 高度互相影响问题;vue this问题;
最终效果图: 一.轮播图中图片自适应宽高: <Carousel loop v-bind:height="imgHeight+'px'" v-model="caro ...
随机推荐
- c#入门系列——类和对象的代码实现
面向对象 说起面向对象,大家因该都听说过,也知道是一个编程的方法,简称oop技术.它将对象的算法和数据结构看作一个整体,而一个程序就是由多个对象结合的整体.这样做可以提高代码的复用率,提高了软件的可维 ...
- 《Effective Objective-C 2.0》 读后总结
感觉自己最近提升很慢了.然后去找了一些面试题看看.发现自己自大了.在实际开发中,让我解决bug.编写功能,我有自信可以完成.但是对项目更深层的思考,我却没有.为了能进到自己的目标BAT.也为了让自己更 ...
- Java IO流学习总结八:Commons IO 2.5-IOUtils
Java IO流学习总结八:Commons IO 2.5-IOUtils 转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/550519 ...
- SQLite基础回顾
SQLite基础回顾 SQLite iOS中的数据存储方式 Plist(NSArray\NSDictionary) Preference(偏好设置\NSUserDefaults) NSCoding(N ...
- HR从业者的下一个十年该怎么做?
众所周知,目前我们所处的以互联网为代表的新经济时代,有两个重要的特征一是客户价值至上,二是人力资本主权.围绕这两个基本特征,我们需要重新架构我们的商业模式和创新人力资源管理思维.模式.工具和方法. 人 ...
- C语言——选择排序
---恢复内容开始--- 算法思想: n个记录的文件的直接选择排序可经过n-1趟直接选择排序得到有序结果: ①初始状态:无序区为R[1..n],有序区为空. ②第1趟排序 在无序区R[1..n]中选出 ...
- 通过映射关系 动态转义为统一格式的数据 (支持 JSON 和 XML )
在很多的时候 我们都会 需要 将不同格式的数据 转换为 统一的数据格式 比如 将Json 源数据 { "b": [ { "c": "referenc ...
- 存储过程与SQL语句如何选择
58到家数据库30条军规,有一条是“禁止使用存储过程.视图.触发器.Event”, 高并发大数据的互联网业务,架构设计思路是“解放数据库CPU,将计算转移到服务层”, 并发量大的情况下,这些功能很可能 ...
- Python求解数组重新组合求最小值(优酷)
题目描述:题目:含有n个元素的整型数组,将这个n个元素重新组合,求出最小的数,如(321,3,32,) 最小数为321323 题目分析: 将数组中所有元素填充到个数相等,填充的数字为最后一位的数字,如 ...
- WebSite---前台系统图片验证码心得
背景: 因为移动端APP和Msite手机注册发送短信验证码没有添加图片验证码功能.公司的短信接口被恶意刷取.所以我们就觉得在移动端添加一个图片验证码功能.分享一下大体实现方式思路.PS demo是自己 ...