css3 flex属性flex-grow、flex-shrink、flex-basis学习笔记
最近在研究css3的flex。遇到的flex:1;这一块,很是很纠结,flex-grow、flex-shrink、flex-basis始终搞不清,最经搜集了大量的介绍,应该能算是明白了。
网上大部分解释是
flex-grow 是扩展比率
flex-shrink 是收缩比率
flex-basis 伸缩基准值
假设flex盒子父级宽度固定为800px;
Flex-grow、Flex-shrink、Flex-basis 是Flex属性的分写模式;
如
.box {
    flex: 4 3 100px;
}
等于
.box {
    flex-grow: 4;
    flex-shrink: 3;
    flex-basis: 100px;
}
看以下例子
<div class="flex-parent">
    <div class="flex-son"></div>
    <div class="flex-son"></div>
    <div class="flex-son"></div>
</div>
<style type="text/css">
    .flex-parent {
        width: 800px;
    }
</style>
第一种情况
flex-parent 是父级,而且他的宽度是固定为800px,不会改变;
开始设置子级flex属性;
<style type="text/css">
    .flex-son:nth-child(1){
        flex: 3 1 200px;
    }
    .flex-son:nth-child(2){
        flex: 2 2 300px;
    }
    .flex-son:nth-child(3){
        flex: 1 3 500px;
    }
</style>
flex-basis总和加起来为1000px; 那么 1000px > 800px (父级的宽度);子元素势必要压缩;溢出了200px;
son1 = (flex-shrink) * flex-basis;
son2 = (flex-shrink) * flex-basis;
…..
sonN = (flex-shrink) * flex-basis;
如果flex-basis的总和加起来大于父级宽度,子级被压缩,最后的选择是flex-shrink来进行压缩计算
加权值 = son1 + son2 + …. + sonN;
那么压缩后的计算公式就是
压缩后宽度 w = (子元素flex-basis值 * (flex-shrink)/加权值) * 溢出值
所以最后的加权值是
1*200 + 2*300 + 3*500 = 2300px
son1的扩展量:(200 * 1/ 2300) * 200,即约等于17px;
son2的扩展量:(300 * 2/ 2300) * 200,即约等于52px;
son3的扩展量:(500 * 3/ 2300) * 200,即约等于130px;
最后son1、son2、son3,的实际宽度为:
200 – 16  = 184px;
300 – 52  = 248px;
500 – 130 = 370px;
第二种情况
上面的例子已经说明,继续看第二个例子,同样上面的例子,我们改下父级宽度为1200px;
flex-basis的总和为 1000px,小于父级宽度,将有200px的剩余宽度;
既然有剩余,我们就不要加权计算,剩余的宽度将根据flex-grow,值得总和进行百分比,那么200px就会根据份数比来分配剩余的空间;
剩余后宽度 w = (子元素flex-grow值 /所有子元素flex-grow的总和) * 剩余值
总分数为 total = 1 + 2 + 3;
son1的扩展量:(3/total) * 200,即约等于100px;
son2的扩展量:(2/total) * 200,即约等于67px;
son3的扩展量:(1/total) * 200,即约等于33px;
最后son1、son2、son3,的实际宽度为:
200 + 100 = 300px;
300 + 67 = 367px;
500 + 33 = 533px;
总结
所以以上两种情况下,第二种flex-basis和flex-shrink是不列入计算公式的;第一种flex-grow是不列入计算公式的
ok,上面的两种情况总结完毕,但是很多时候我们的父级是不固定的,那么怎么办,其实很简单了,对照上面的公式,前提是已经设置了flex-basis值得元素,如果宽度的随机值小于flex-basis的时候就按第一种计算,反之第二种;明白了吧。
但是在实际中,我们有些子元素不想进行比例分配,永远是固定的,那么flex就必须设置为none;
否则设置的宽度(width)将无效;
flex: 1,    则其计算值为 flex: 1 1 0%;
flex: auto, 则其计算值为 flex: 1 1 auto;
flex: none, 则其计算值为 flex: 0 0 auto;
根据上面的公式
flex:1的时候第一种方式其实是无效的,因为加权值是0,所以只能是第二种方式计算;
flex:none的时候,两种都失效,自己元素不参与父级剩余还是溢出的分配,flex:none的应用场景还是很多的;
css3 flex属性flex-grow、flex-shrink、flex-basis学习笔记的更多相关文章
- CSS 弹性盒子 flex的三个属性:grow、shrink、basis
		
flex-grow 首先介绍flex-grow属性,flex-grow会在容器太大时(图片A.B的宽度和 < 父容器宽度)对元素作出调整. 如果图片A的flex-grow属性的值为 1,图片B的 ...
 - 前端flex布局学习笔记
		
flex布局,即为弹性布局,其为盒模型提供最大的灵活性,任何一个容器都可以指定为flex布局. eg:.box{ display:flex: } 行内元素也可以使用flex布局. 注意:设置flex布 ...
 - H5、CSS3属性的支持性以及flex
		
一.项目中用到一个flex属性,但是应用了flex的父容器只设置了width,没有设置height,此时每一个应用了上面提到的属性的样式的div都重叠在了一起,在IE10,IE11出问题,IE9没有问 ...
 - C#可扩展编程之MEF学习笔记(三):导出类的方法和属性
		
前面说完了导入和导出的几种方法,如果大家细心的话会注意到前面我们导出的都是类,那么方法和属性能不能导出呢???答案是肯定的,下面就来说下MEF是如何导出方法和属性的. 还是前面的代码,第二篇中已经提供 ...
 - CSS3动画属性和flex弹性布局各个属性
		
[CSS3动画的使用] 1.声明一个关键帧(动画): @keynames name{ from{} to{} } 每个阶段的写法: ①可以直接使用from-to的写法 ②可以设置0%-100%的写法, ...
 - CSS3新属性之---flex box布局实例
		
flex box布局实例 flex的强大之处在于不管什么布局,几行命令即可实现 /*本节模板div元素(代表骰子的一个面)是Flex容器,span元素(代表一个点)是Flex项目.如果有多个项目,就要 ...
 - CSS3弹性伸缩布局(二)——flex布局
		
上一篇博客<CSS3弹性伸缩布局(一)——box布局>介绍了旧版本的box布局,而这篇博客将主要介绍最新版本的flex布局的基础知识. 新版本简介 新版本的Flexbox模型是2012年9 ...
 - flex属性的学习
		
1.需要记住的属性和值. ------------------------------------------------------------- 方向横和纵 flex-direction: row ...
 - CSS3 Flex布局(伸缩布局盒模型)学习
		
CSS3 Flex布局(伸缩布局盒模型)学习 转自:http://www.xifengxx.com/web-front-end/1408.html CSS2定义了四种布局:块布局.行内布局.表格布局盒 ...
 
随机推荐
- SQL学习笔记:基础教程
			
SQL语法 在表中选择列 select 列名 from 表名 选择所有列 select * from 表名 返回唯一值 select distinct 列名 from 表名 where select ...
 - 20155209实验二《Java面向对象程序设计》
			
20155209实验二<Java面向对象程序设计> 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 了解设计 ...
 - 20155211 2016-2017-2 《Java程序设计》第十周学习总结
			
20155211 2016-2017-2 <Java程序设计>第十周学习总结 教材学习内容总结 网络编程的实质就是两个(或多个)设备(例如计算机)之间的数据传输 在实际传输数据以前需要将域 ...
 - 20155233 《Java程序设计》实验五 Java网络编程及安全
			
实验内容 1.掌握Socket程序的编写: 2.掌握密码技术的使用: 3.设计安全传输系统. 实验1 两人一组结对编程: 0. 参考http://www.cnblogs.com/rocedu/p/67 ...
 - 20145209 实验四 《android开发基础》 实验报告
			
20145209 实验四 <android开发基础> 实验报告 实验内容 Android Stuidio的安装测试: 参考<Java和Android开发学习指南(第二版)(EPUBI ...
 - day6 break continue for
			
.for .break (整个while循环全部结束) )打印1-100的偶数.py )打印1-100的20个偶数.py )while嵌套中的break (就近原则) .continue 错误用法: ...
 - ptyhon基础篇  day1
			
1.变量 print('helloworld!') name = 'alex' name2 = 'jack' print(name,name2) 2.input #用户输入 username = in ...
 - spring源码-aop源码-5.1
			
一.aop的源码部分还是有点复杂的,但是为了更好的理解,我这里会省去很多不必要的逻辑实现过程.主要方向还是更好的理解整体代码的实现过程. 二.说明重点:aop的过程主要过程有两点:第一点,发现正确和适 ...
 - L015-linux系统文件权限体系手把手详解小结
			
L015-linux系统文件权限体系手把手详解小结 2016-5-24 今天星期二,昨天和今天利用一些闲散时间把第15节课学完了,最近有点懒散哈,还得努力才是.. 这节课内容不多,扩展的也少,主要就是 ...
 - 九、EnterpriseFrameWork框架基础功能之消息管理
			
记得阿朱在<走出软件作坊>一书中有一章讲客户提的需求太邪门了,鼠标键盘不太会用要程序员开发一个语音输入功能,还要系统中带类似QQ的功能:确实刚开始的客户的想法有点天真,但是随着信息化的越来 ...