用css3的flex好久了,虽然用的没问题,但还是很纠结,其他属性大都明白,但是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 – 230 = 370px;

看demo http://www.heibaipig.com/demo/flex/demo1.html

第二种情况

上面的例子已经说明,继续看第二个例子,同样上面的例子,我们改下父级宽度为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;

看demo http://www.heibaipig.com/demo/flex/demo1.html

总结

所以以上两种情况下,第二种flex-basisflex-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学习笔记相关推荐

  1. flex的三个属性grow、shrink、basis

    个人理解 flex-grow:0; 默认值为0,容器中项目没有占满时,不分配剩余空间. flex-shrink:1; 默认值为1,容器中项目超出容器大小时,把项目平均压缩到容器内. flex-basi ...

  2. 深入了解 Flex 属性

    作者:Ahmad shaded 译者:前端小智 来源:sitepoint 移动端阅读:https://mp.weixin.qq.com/s/Tw7gezAn-ld97u8hkyD3kA 点赞再看,微信 ...

  3. html+css:display:flex属性

    博客 </a></li><li class="" title="高价值源码课程分享"><a data-report-c ...

  4. 弹性布局flex属性详解

    注意:如果元素不是弹性盒模型对象的子元素,则 flex 属性不起作用. flex 属性用于设置或检索弹性盒模型对象的子元素如何分配空间. flex 属性是 flex-grow.flex-shrink ...

  5. flex布局一行三个_CSS Flex布局

    Flex之前 在flex布局出现以前,css布局大致就以下几种布局: 主要使用: normal flow 正常流.文档流 float + clearfix position: relative + p ...

  6. Mr.J-- jQuery学习笔记(三十二)--jQuery属性操作源码封装

    扫码看专栏 jQuery的优点 jquery是JavaScript库,能够极大地简化JavaScript编程,能够更方便的处理DOM操作和进行Ajax交互 1.轻量级 JQuery非常轻巧 2.强大的 ...

  7. CSS3 Flex布局(伸缩布局盒模型)学习

    CSS3 Flex布局(伸缩布局盒模型)学习 转自:http://www.xifengxx.com/web-front-end/1408.html CSS2定义了四种布局:块布局.行内布局.表格布局盒 ...

  8. 详解 CSS3中最好用的布局方式——flex弹性布局(看完就会)

    文章包含个人理解,错误请指出. 往期css3文章 CSS3基础属性大全 CSS3动画属性 animation详解(看完就会) CSS3 transform 2D转换之移动 旋转 缩放(详细讲解看完就会 ...

  9. CSS - Flex属性 - flex-grow / flex-shrink / flex-basis

    用css3的flex好久了,虽然用的没问题,但还是很纠结,其他属性大都明白,但是flex-grow.flex-shrink.flex-basis始终搞不清,最经搜集了大量的资料,总算是明白了. 网上大 ...

最新文章

  1. QT4到QT5的变化!
  2. 安装博图v15每次让重启计算机,博途V15.1安装及无限重启和.net3.5SP1错误处理解决方法...
  3. 快搜浏览器_郑秀晶因腿粗再上热搜:怎么减肥才能不反弹?
  4. 微型计算机物理地址转换,微型计算机及接口技术2015年4月真题试题(04732)
  5. Dapr牵手.NET学习笔记:用docker-compose部署服务
  6. 【POJ - 2318】TOYS(计算几何,叉积判断点与直线位置关系,二分)
  7. 虚拟机中的linux系统联网,虚拟机上Linux系统上网设置
  8. ReactiveSwift源码解析(二) Bag容器的代码实现
  9. Spring MVC深入讲解
  10. 常见电脑故障自检指南(南城ZW)
  11. 15岁黑客Cosmo的堕落历程
  12. AXI4 Increase burst / wrap burst/ fix burst 和 narrow transfer
  13. RabbitMQ登录时guest用户提示User can only log in via localhost
  14. 实时采集福利彩票的中奖信息和最新开奖信息-JAVA
  15. 国外渗透教学——CBT 国外的道德黑客Nuggets
  16. Run-down Protection
  17. 3D灯光教程仅需三个步骤,用ThingJS体验极速开发!
  18. python安装绘图库matplotlib_python绘图库Matplotlib的安装
  19. ssm+jsp计算机毕业设计招标采购管理系统79n8o(程序+lw+源码+远程部署)
  20. 主编编辑器如何收藏素材?

热门文章

  1. python基础语法类型_Python基础入门语法和变量类型(一)
  2. 为什么python不需要编译_为什么我用Go写机器学习部署平台,而偏偏不用Python?...
  3. warpaffine 旋转有一部分消失_如果月球消失了,会发生什么?我们的世界又将会变得怎么样?...
  4. python如何循环执行_如何在python中多次运行for循环?
  5. INF=0x3f3f3f3f背后的知识
  6. 描写计算机老师上课的神态,请你用一段话描写一位老师上课的情景,注意抓住神态语言动作等细节...
  7. 雷军宣布:启动小米成立以来最大组织架构变革(附内部邮件原文)
  8. DiscuzX系列命令执行分析公开(三连弹)
  9. 看了些关于rem的知识点,在这做个自我总结归纳
  10. 无法删除sqlserver的jobs的方式