flex-grow、flex-shrink、flex-basis三个属性的作用:

在flex布局中,父元素在不同宽度下,子元素是如何分配父元素空间的。

(注意:这三个属性都是在子元素上设置的,下面小编要讲的是父元素,指以flex布局的元素(display:flex))

小编这里先教一下大家如何快速记住这三个属性:

首先是   flex-basis  ,basis英文意思是<主要成分>,所以他和width放在一起时,肯定把width干掉,basis遇到width时就会说我才是最主要的成分,你是次要成分,所以见到我的时候你要靠边站。

其次是   flex-grow,grow英文意思是<扩大,扩展,增加>,这就代表当父元素的宽度大于子元素宽度之和时,并且父元素有剩余,这时,flex-grow就会说我要成长,我要长大,怎么样才能成长呢,当然是分享父元素的空间了。见下面第二个属性的内容

最后是   flex-shrink, shrink英文意思是<收缩,>,这就代表当父元素的宽度小于子元素宽度之和时,并且超出了父元素的宽度,这时,flex-shrink就会说外面的世界太苦了,我还是回到父亲的怀抱中去吧!因此,flex-shrink就会按照一定的比例进行收缩。见下面第三个属性的内容

第一个属性:flex-basis

该属性用来设置元素的宽度,其实,width也可以设置宽度。如果元素上同时设置了width和flex-basis,那么width 的值就会被flex-basis覆盖掉。

<style type="text/css" media="screen">.box{display: flex;margin:100px auto;width:400px;height:200px;}.inner{   width:200px;height:100px; flex-basis:300px;background:pink;}</style>
</head>
<body>
<div class="box"><div class="inner"></div>
</div>
</body>

见下图:小编我把宽度设置为width:200px;  flex-basis:300px;结果显示表明子元素.inner应用了属性flex-basis;

第二个属性:flex-grow

该属性用来设置当父元素的宽度大于所有子元素的宽度的和时(即父元素会有剩余空间),子元素如何分配父元素的剩余空间。 flex-grow的默认值为0,意思是该元素不索取父元素的剩余空间,如果值大于0,表示索取。值越大,索取的越厉害。

举个例子: 父元素宽400px,有两个子元素:A和B。A宽为100px,B宽为200px。 则空余空间为 400-(100+200)= 100px。 如果A,B都不索取剩余空间,则有100px的空余空间。

<body>
<div class="box"><div class="inner"></div><div class="inner1"></div>
</div>
</body>
.box{display: flex;flex-direction: row;margin:100px auto;width:400px;height:200px;border:1px solid red;}.inner{flex-basis:100px;height:100px;background:pink;}.inner1{flex-basis:200px;height:100px;background:blue;}

见下图:

如果A索取剩余空间:设置flex-grow为1,B不索取。则最终A的大小为 自身宽度(100px)+ 剩余空间的宽度(100px)= 200px 。

 .inner{flex-basis:100px;height:100px;background:pink;flex-grow:1;}.inner1{flex-basis:200px;height:100px;background:blue;}

见下图:

如果A,B都设索取剩余空间,A设置flex-grow为1,B设置flex-grow为2。则最终A的大小为 自身宽度(100px)+ A获得的剩余空间的宽度(100px (1/(1+2))),最终B的大小为 自身宽度(200px)+ B获得的剩余空间的宽度(100px (2/(1+2)))(这里呢小编只给了公式,小伙伴们可以自己去算一下)

.inner{flex-basis:100px;height:100px;background:pink;flex-grow:1;}.inner1{flex-basis:200px;height:100px;background:blue;flex-grow:2;}

见下图:

第三个属性:flex-shrink

该属性用来设置,当父元素的宽度小于所有子元素的宽度的和时(即子元素会超出父元素),子元素如何缩小自己的宽度的。 flex-shrink的默认值为1,当父元素的宽度小于所有子元素的宽度的和时,子元素的宽度会减小。值越大,减小的越厉害。如果值为0,表示不减小。

举个例子: 父元素宽400px,有两子元素:A和B。A宽为200px,B宽为300px。 则A,B总共超出父元素的宽度为(200+300)- 400 = 100px。 如果A,B都不减小宽度,即都设置flex-shrink为0,则会有100px的宽度超出父元素。

 .box{display: flex;flex-direction: row;margin:100px auto;width:400px;height:200px;border:1px solid red;}.inner{flex-basis:200px;height:100px;background:black;flex-shrink:0;}.inner1{flex-basis:300px;height:100px;background:blue;flex-shrink:0;}

见下图:

如果A不减小宽度:设置flex-shrink为0,B减小。则最终B的大小为 自身宽度(300px)- 总共超出父元素的宽度(100px)= 200px

.inner{flex-basis:200px;height:100px;background:black;flex-shrink:0;}.inner1{flex-basis:300px;height:100px;background:blue;flex-shrink:1;}

见下图:

如果A,B都减小宽度,A设置flex-shirk为3,B设置flex-shirk为2。则最终A的大小为 自身宽度(200px)- A减小的宽度(100px * (200px * 3/(200 * 3 + 300 * 2))) = 150px,最终B的大小为 自身宽度(300px)- B减小的宽度(100px * (300px * 2/(200 * 3 + 300 * 2))) = 250px

.inner{flex-basis:200px;height:100px;background:black;flex-shrink:3;}.inner1{flex-basis:300px;height:100px;background:blue;flex-shrink:2;}

见下图:

这里小编明确一点,flex是flex-grow,flex-shrink,  flex-basis  (注意小编写的顺序)缩写形式,大家可以记一下下面的缩写规则:

如:flex 取值为 none,则计算值为 0 0 auto,如下是等同的:

.item {flex: none;}
.item {flex-grow: 0;flex-shrink: 0;flex-basis: auto;
}

当 flex取值为 auto,则计算值为 1 1 auto,如下是等同的:

.item {flex: auto;}
.item {flex-grow: 1;flex-shrink: 1;flex-basis: auto;
}

当 flex 取值为一个非负数字,则该数字为 flex-grow 值,flex-shrink 取 1,flex-basis 取 0%,如下是等同的:

.item {flex: 1;}

.item {flex-grow: 1; flex-shrink: 1; flex-basis: 0%;}

当 flex 取值为一个长度或百分比,则视为 flex-basis 值,flex-grow 取 1,flex-shrink取 1,有如下等同情况(注意 0% 是一个百分比而不是一个非负数字):

.item-1 {flex: 0%;}
.item-1 { flex-grow: 1; flex-shrink: 1; flex-basis: 0%;} .item-2 {flex: 24px;} .item-2 { flex-grow: 1; flex-shrink: 1; flex-basis: 24px;}

当 flex取值为两个非负数字,则分别视为 flex-grow和 flex-shrink的值,flex-basis取 0%,如下是等同的:

.item {flex: 2 3;} .item { flex-grow: 2; flex-shrink: 3; flex-basis: 0%;} 当 flex取值为一个非负数字和一个长度或百分比,则分别视为 flex-grow和 flex-basis的值,flex-shrink取 1,如下是等同的: .item {flex: 2333 3222px;} .item { flex-grow: 2333; flex-shrink: 1; flex-basis: 3222px;} 

css弹性盒子-------桃园三兄弟之:flex-grow、flex-shrink、flex-basis详解相关推荐

  1. css 弹性盒子 flex布局

    目录 css弹性盒子flex 布局 什么是flex 常见父项属性 概念与案例 主轴与侧轴 flex-direction设置主轴的方向 justify-content 设置主轴上的子元素排列方式 fle ...

  2. CSS弹性盒子布局——flex布局的基本概念

    <CSS弹性盒子布局--flex布局的基本概念> Flexible Box 模型,通常被称为 flexbox,是一种一维的布局模型.它给 flexbox 的子元素之间提供了强大的空间分布和 ...

  3. 【CSS 弹性盒子布局 (Flexible Box Layout)】

    CSS 弹性盒子布局 Flexible Box Layout CSS 弹性盒子布局 (Flexible Box Layout) 1. 弹性盒子布局的 基本概念和术语 2. flex 属性: 设置 伸缩 ...

  4. CSS 弹性盒子布局详解

    CSS 弹性盒子 弹性盒子是CSS3的一种新布局模式.是一种当页面需要适应不同的屏幕大小以及设备类型时确保元素拥有恰当的行为的布局方式. 弹性盒子布局是一种在前端HTML开发中比较常用的布局方式,还有 ...

  5. CSS 弹性盒子布局使用方法介绍

    标题 CSS 弹性盒子布局 CSS 属性 应用在父容器元素上的CSS属性 1.display: flex | inline-flex; 2. flex-direction 3. flex-wrap 4 ...

  6. Iterator主要有三个方法:hasNext()、next()、remove()详解

    Iterator主要有三个方法:hasNext().next().remove()详解 一.Iterator的API 关于Iterator主要有三个方法:hasNext().next().remove ...

  7. flex+php ria应用开发实战详解光盘,《Flex+PHPRIA应用开发实战详解-梁文新版》学习日记2...

    这本书真是折磨啊,今天看到了XML解析部分,文章在介绍函数及其参数时很是仔细,但是这本没有把源码最终写清楚,总是少一部分,xml和php对大小写不是很敏感,均能读出来,今天也遇到一个乱码问题,希望这方 ...

  8. flex+php ria应用开发实战详解,《Flex+PHP RIA应用开发实战详解-梁文新版》学习日记2...

    这本书真是折磨啊,今天看到了XML解析部分,文章在介绍函数及其参数时很是仔细,但是这本没有把源码最终写清楚,总是少一部分,xml和php对大小写不是很敏感,均能读出来,今天也遇到一个乱码问题,希望这方 ...

  9. [Python图像处理] 三十三.图像各种特效处理及原理万字详解(毛玻璃、浮雕、素描、怀旧、流年、滤镜等)...

    此文转载自:https://blog.csdn.net/Eastmount/article/details/111568397#commentBox 该系列文章是讲解Python OpenCV图像处理 ...

最新文章

  1. 是时候了解一下Serverless了
  2. 自执行匿名函数剖析整理
  3. 锚杆拉拔试验弹性模量计算_【安全宣教】煤亮子小课堂(十三)——锚杆的锚固力和拉拔力...
  4. ftp可以传输什么类型文件_为什么文件传输软件总让数据“没有安全感”?
  5. 卸载linux订阅包
  6. C++接收字符串数组_C语言处理字符串的7个函数
  7. 经常使用的正則表達式归纳—JavaScript正則表達式
  8. morhpia(4)-更新
  9. 什么是反向跟单?反向跟单怎么运作?
  10. win7装matlab教程,win7系统怎么安装matlab软件(图文教程)
  11. DLL劫持技术解析(DLL Hijack)
  12. Lance老师UI系列教程第三课-QQ登录注册界面的实现(android-2012最新版)
  13. 使用Java集合实现麻将(准备牌、洗牌、发牌、看牌)
  14. 程序人生:为什么现在的年轻人看不到希望?
  15. 【Python融于生活】之我想要保存QQ邮箱富途的附件
  16. [Excel]Excel函数和用法(4)——查找字符串,SEARCH和FIND函数
  17. 代码编辑神器--VSCode
  18. 德国警方捣毁暗网重要节点
  19. NSArray/NSMutableArray基础操作
  20. Halcon畸变矫正流程

热门文章

  1. TDSQL PG版再升级,深度参与开源生态建设
  2. 15 基于STM32智能路灯灯光自动控制系统设计
  3. braintree_Laravel和Braintree,坐在树上……
  4. 树莓派4b入门之开发RFID系统—简介、搭建MFRC522-SPI环境
  5. 程序员三十而立,应如何选择才能继续将技术路线走下去?
  6. mix2刷android p教程,小米Mix2 Xposed框架刷入及升级详细图文教程
  7. 「镁客·请讲」关于VR行业内容发展破局之道,我们和水晶石做了一番走心的交流...
  8. 【目标检测论文解读复现NO.27】基于改进YOLOv5的螺纹钢表面缺陷检测
  9. 一文带你体验CentOS7防火墙firewall
  10. Paper——基于Ubuntu18.04跑通Lift, Splat, Shoot