CSS 弹性盒子 flex的三个属性:grow、shrink、basis
flex-grow
首先介绍flex-grow属性
,flex-grow
会在容器太大时(图片A、B的宽度和 < 父容器宽度)对元素作出调整。
如果图片A的flex-grow
属性的值为 1,图片B的flex-grow
为 2,那么 2 的会比 1 的扩大两倍:
也许“扩大两倍”这个概念不便于理解,我们可以换一种说法。
首先要理解一个词“剩余空间”:具备flex环境的父容器(display:flex;)默认有一条从左往右
的主轴,而剩余空间就是父容器在主轴方向上还有多少可用空间。例如现在有一个父容器container宽度为500px,
而图A+图B为300px,则剩余空间为200px。此时,图片A的flex-grow
属性的值为 1,图片B的flex-grow
为 2,
则剩余空间200px将被分为1+2=3份,其中一份分给图片A,两份分给图片B,也就是上面所说的图片A比图片B多扩大两倍。
flex-shrink
默认情况下,flex是不换行的,即使内容的宽度超过了父容器的宽度也不会,除非设置flex-wrap来换行。
flex-shrink
属性。flex-grow
会在容器太大时对元素作出调整。相应地,使用flex-shrink之后,
如果 flex 容器太小,该项目会自动缩小。当容器的宽度小于里面所有项目的宽度,项目就会自动压缩。
flex-shrink
属性接受 number 类型的值。数值越大,与其他项目相比会被压缩得更厉害。例如,
如果图片A的flex-shrink
为 1 ,图片B的flex-shrink
为 2,那么 2 的那个与 1 相比会受到 2 倍压缩:
而实际的压缩率是多少呢?在实际内容宽度大于父容器的情况下,
剩余空间就自然地变为了负数,也就暂时不起作用。这里假设图片A 200px 图片B 200px,父容器300px。
设图片A B的压缩率是X1 X2,则有方程:
X2 = 2 * X1
300 = 200*X1 + 200*X2,求得压缩率。
(如果你不想让内容被压缩,则可设置flex-shrink为0)
flex-basis
flex-basis
属性指定了项目在 CSS 进行flex-shrink
或flex-grow
调整前的初始大小。功能上等价于width,但优先级比width高。
flex-basis
属性的单位与其他 size 属性一致(px
、em
、%
等)。如果值为auto
,项目的大小依赖于自身内容。
在这里,图片A的flex-basis为10em,图片B的flex-basis为20em:
flex 短方法
上面几个 flex 属性有一个简写方式。flex-grow
、flex-shrink
和flex-basis
属性可以在flex
中一同设置。
例如,图片A flex: 2 2 150px;
会把项目属性设为flex-grow: 2;
、flex-shrink: 2;
以及flex-basis: 150px;
图片B flex: 1 1 150px;
会把项目属性设为flex-grow: 1;
、flex-shrink: 1;
以及flex-basis: 150px;
。
(flex 属性的默认设置是flex: 0 1 auto;)
当容器宽度小于150+150=300px时,会让图片A的缩小倍率为图片B的两倍(缩小得更快):
当容器宽度大于300px时,会让图片A的填充倍率为图片B的两倍(扩增得更快):
部分内容参考自:https://learn.freecodecamp.one/
CSS 弹性盒子 flex的三个属性:grow、shrink、basis的更多相关文章
- 使用css弹性盒子模型
提示: 当期内容不充实, 修改后再来看吧 以下称:弹性子元素: 子元素, 弹性容器: 容器 弹性盒子的属性 1. css弹性盒子模型规定了弹性元素如何在弹性容器内展示 2. 弹性元素默认显示在弹性容器 ...
- CSS3总结五:弹性盒子(flex)、弹性盒子布局
弹性盒子容器的属性与应用 display:flex/inline-flex flex-direction flex-wrap justify-content align-items align-con ...
- 认识弹性盒子flex
认识弹性盒子flex 来源:https://blog.xybin.top/2022/flex 1.定义弹性布局(父级上定义)display:flex; 如果说内核为webkit 的必须前面加上 -we ...
- CSS3 弹性盒子(Flex Box)
1 CSS3 弹性盒子(Flex Box) 1 http://caniuse.com/#search=flex%20box https://www.w3.org/TR/css-flexbox-1/ C ...
- CSS 弹性盒子模型
CSS 弹性盒子模型 https://www.w3.org/TR/2016/CR-css-flexbox-1-20160526/ CSS Flexible Box Layout Module Leve ...
- CSS:CSS弹性盒子布局 Flexible Box
一.简介 flexbox:全称Flexible Box, 弹性盒子布局.可以简单实现各种伸缩性的设计,它是由伸缩容器和伸缩项目组成.任何一个元素都可以指定为flexbox布局.这种新的布局方案在200 ...
- css弹性盒子学习
css3弹性盒子是一种布局方式,在适应不同的屏幕大小的时候,能够确保元素拥有更恰当的排布行为.它只是视觉呈现上的,即显示顺序适应显示空间,与源代码无关,源代码顺序不受影响. 定义一个弹性盒子: 在cs ...
- css弹性盒子新旧兼容
前言:本篇随笔是对弹性盒子有了解的人来写的这篇文章,具体属性产生的效果这里不做说明,基础的东西去查文档.这里只是总结. 时至今日,css3的flex弹性盒子在移动端基本上都是支持的,但不排除有些些低版 ...
- CSS弹性盒子的基本用法
.container { width: 302px; height: 302px; border: 1px solid; display: flex } .item { width: 100px; h ...
随机推荐
- Mixin类的实现
python类的多重继承由于C3算法的原因导致实现时需要提前规划先后顺序才能正常使用. 这会让人在python中使用多重继承时感到十分的麻烦. 而Mixin类则为我们带来了自由的多重继承和插拔式的舒适 ...
- Matplotlib 教程
Matplotlib是python中最流行的数据绘图库,使用matplotlib,您可以绘制任何类型的图形. 本教程的目标是让您轻松学会使用matplotlib绘制复杂的图形. 预备知识 熟悉Pyth ...
- 使用PYaudio录制音频和视频(自己)
参考:https://blog.csdn.net/zhaoyun_zzz/article/details/84341801 音频录制:简洁版 import pyaudioimport waveimpo ...
- hue中访问hdfs报错
在hue中访问hdfs报错: Cannot access: /. Note: you are a Hue admin but not a HDFS superuser, "hdfs" ...
- 面试题之xml解析?
题目是:用java程序将xml中的数据保存到实体对象中,如何实现? xml如下: <?xml version="1.0" encoding="UTF-8" ...
- Oralce给字段追加字符,以及oracle 给字段替换字符
追加字符 update table_name t set t.DIST_NAME = t.DIST_NAME || '市' where PROD_NAME='爱立信' table_name :表名 ...
- window 命令行telnet 不能用问题
如图 解决办法 打开window控制面板,启用或关闭window功能,勾选telnet选项.
- Element-UI Table 实现筛选数据功能
最近产品提出了一个筛选数据的功能,要求在表头里实现一个下拉框进行筛选. 首先, Element-ui 的官方文档,el-table-column 下有一个 filters , 用于数据的筛选和过滤, ...
- 002. 使用IDEA创建MyBatis的JAVAWEB项目 ,每一步都有详细过程,完美绕过各种坑能正常运行
001. 我们新建一个Module,相当于一个工程里面的一个项目 002.选择空白的JAVA程序 003.输入项目的名字为mybatis001 004.我们对这个项目添加Support,各种框架依赖 ...
- 嵊州普及Day1T2
题意:走迷宫.求走到a[n][n]需要多久. 考场上想的dfs,听老师说最多50分.代码懒得码了,知道是走迷宫就好. 正解:bfs,时间复杂度O(n). 见代码: #include<iostre ...