导读:

弹性盒子是 CSS3 的一种布局模式,一种当页面需要适应不同的屏幕大小以及设备类型时确保元素拥有适当的行为的布局方式。其中 flex 属性用于指定弹性子元素如何分配空间。

flex 属性的值

  • flex-grow flex-shrink flex-basis (flex-grow为扩展比率,flex-shrink为收缩比率,flex-basis为默认基准值)
  • auto (计算值为 1 1 auto)
  • initial (计算值为 0 1 auto)
  • none (计算值为 0 0 auto)
  • inherit (从父元素继承)

所以之前你也许看过:

flex: 0 1 auto;

这样的缩写,它依次包含 flexbox 的 3 个属性,依次是 flex-grow(默认值:0),flex-shrink(默认值:1),flex-basis。本文主要讲解 flexbox 的这三个属性,需要对 flexbox 具有初步的了解。

flex-basis

flex-basis 属性指定了 flex 元素在主轴方向上的初始大小,决定了可伸缩的空间大小(剩余空间)。所以要知道剩余空间的大小,必须先知道 flex-basis 属性的值:

如果没有设置 flex-basis 属性,那么 flex-basis 的大小就是项目的 width 属性的大小。
如果没有设置 width 属性,那么 flex-basis 的大小就是项目内容(content)的大小。

flex-basis 与 flex-grow

首先我们创建一个宽为 1000px 的 flex 容器。然后通过给其子元素定义不同的 flex 属性值来查看它们的布局。

2 0 250px;
0 0 200px;
2 0 150px;

现在我们来计算设置 flex 属性不同值之后每个子元素的宽度。首先,我们来计算剩余空间:

剩余空间 = 容器大小 - 每个子元素的 flex-basis 值的总和

根据上面的例子,这里的 剩余空间 = 1000 - (250 + 200 + 150) = 400

然后剩余空间根据各子元素中 flex-grow 的值平均分配,所以子元素最终的宽度计算为:

每个子元素的最终空间 = 伸缩基准值 + 剩余空间 / (各子元素中 flex-grow) * 对应子元素的 flex-grow

此处第一子元素的宽度计算为:250 + 400/(2+0+2)*2 = 450。第二子元素的宽度计算为:200 + 400/(2+0+2)*0 = 200。第三子元素的宽度计算为:150 + 400/(2+0+2)*2 = 350

flex-basis 与 flex-shrink

flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。flex-shrink 的计算方式与 flex-grow 大有不同,下面我们定义一个宽为 600px 的 flex 容器。然后通过给其子元素定义不同的 flex 属性值(默认宽度之和大于容器)来查看它们的布局。

2 2 200px;
0 1 400px;
2 1 200px;

现在我们要先计算的是负空间:

负空间 = 容器大小 - 每个子元素的 flex-basis 值的总和

在这里 负空间 = 600 - (200+400+200) = -200

其次将每个子元素的收缩比例值乘以各自对应的基准值,再把所得的积累加。

元素空间总和 = 元素一(200) * 元素一的收缩比例(2) + 元素二(400) * 元素二的收缩比例(1) + 元素三(200) * 元素三的收缩比例(1) = 1000

在计算各项的收缩因素(以元素三举例):

各元素收缩因素(三) = 各元素收缩系数(1) * 对应元素的基准值(200) / 元素空间总和(1000) = 0.2

最后计算出各元素收缩的值,从而得到最终的宽度(依然以元素三举例):

各元素收缩值(三) = 对应的收缩因素(0.2) * 负空间(-200) = -40 各元素最终宽度(三) = 基准值(200) + 对应元素的收缩值(-40) = 160

如果各子元素的的 flex-basis 设置为 0 (width也可以),那么计算剩余空间的时候将不会为子容器预留空间。最后呈现出的布局,各子元素空间根据 flex-grow 成比例关系。

flex 属性的运用

有时候我们会需要这样的布局,即让一个 div 永远出现在界面的最底部:当页面内容不足以布满整个屏幕时,该 div 固定在屏幕底部,当内容增加超过页面时,该 div 又固定在页面内容的底部。

实现这个布局的方法有多种,这里介绍一下如何使用弹性盒子的 flex 属性来实现。

HTML结构:

<body>
<div class="content"></div>
<div class="footer"></div>
</body>

CSS结构:

body {
display: -webkit-flex;
display: flex;
-webkit-flex-direction: column;
flex-direction: column;
min-height: 100vh;
}
.content {
-webkit-flex: 1;
flex: 1;
}

写在最后

到此这三个属性之间的计算也就结束了,写得可能有些乱,仅供参考吧,也算作是自己的学习笔记,如果文中有什么错误,欢迎大家指正,愿与大家在交流之中共同进步,愈激烈,愈深刻。感谢。

详解 Flexible Box 中的 flex 属性的更多相关文章

  1. 第7.24节 Python案例详解:使用property函数定义属性简化属性访问代码实现

    第7.24节 Python案例详解:使用property函数定义属性简化属性访问代码实现 一.    案例说明 本节将通过一个案例介绍怎么使用property定义快捷的属性访问.案例中使用Rectan ...

  2. 详解 $_SERVER 函数中QUERY_STRING和REQUEST_URI区别

    详解 $_SERVER 函数中QUERY_STRING和REQUEST_URI区别 http://blog.sina.com.cn/s/blog_686999de0100jgda.html   实例: ...

  3. 详解 Go 语言中的 time.Duration 类型

    swardsman详解 Go 语言中的 time.Duration 类型swardsman · 2018-03-17 23:10:54 · 5448 次点击 · 预计阅读时间 5 分钟 · 31分钟之 ...

  4. 详解jquery插件中(function ( $, window, document, undefined )的作用。

    1.(function(window,undefined){})(window); Q:(function(window,undefined){})(window);中为什么要将window和unde ...

  5. zz详解深度学习中的Normalization,BN/LN/WN

    详解深度学习中的Normalization,BN/LN/WN 讲得是相当之透彻清晰了 深度神经网络模型训练之难众所周知,其中一个重要的现象就是 Internal Covariate Shift. Ba ...

  6. [转载]详解网络传输中的三张表,MAC地址表、ARP缓存表以及路由表

    [转载]详解网络传输中的三张表,MAC地址表.ARP缓存表以及路由表 虽然学过了计算机网络,但是这部分还是有点乱.正好在网上看到了一篇文章,讲的很透彻,转载过来康康. 本文出自 "邓奇的Bl ...

  7. 详解WebService开发中四个常见问题(2)

    详解WebService开发中四个常见问题(2)   WebService开发中经常会碰到诸如WebService与方法重载.循环引用.数据被穿该等等问题.本文会给大家一些很好的解决方法. AD:WO ...

  8. 详解WebService开发中四个常见问题(1)

    详解WebService开发中四个常见问题(1)   WebService开发中经常会碰到诸如WebService与方法重载.循环引用.数据被穿该等等问题.本文会给大家一些很好的解决方法. AD:WO ...

  9. 详解Python编程中基本的数学计算使用

    详解Python编程中基本的数学计算使用 在Python中,对数的规定比较简单,基本在小学数学水平即可理解. 那么,做为零基础学习这,也就从计算小学数学题目开始吧.因为从这里开始,数学的基础知识列位肯 ...

随机推荐

  1. opencv图像的基本操作3

    1.获取像素并修改 读取一副图像,根据像素的行和列的坐标获取它的像素值,对于RGB图像而言,返回RGB的值,对于灰度图则返回灰度值 import cv2 import numpy img = cv2. ...

  2. HDU 1816 Get Luffy Out *

    Get Luffy Out * Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  3. vue证明题五,组件传值与绑定

    上文中写了一个input组件,该组件需要复用,但是并不是每个组件都相同的 比如我定义了一个组件,是个矿泉水瓶子,这个瓶子分为大中小三个号,定义了三种瓶子的容积,定义了必须有瓶盖,瓶口,瓶子质地 但是瓶 ...

  4. Spring高频率面试题

    1.Spring怎样定义类的作用域 通过bean 定义中的scope属性来定义. 2.Spring支持的几种bean的作用域 支持以下五种bean的作用域: singleton : bean在每个Sp ...

  5. 你了解SEO中的时效性吗?

    你了解SEO中的时效性吗? 本文摘自web前端早读课,侵删. 前言 最近刚好在负责一个新项目,App在还没上线的前提上,PC/WAP可以优先部署相关SEO,这样在后续的推广中得以运用.今日早读文章由腾 ...

  6. 【机器学习实验】scikit-learn的主要模块和基本使用

    [机器学习实验]scikit-learn的主要模块和基本使用 引言 对于一些开始搞机器学习算法有害怕下手的小朋友,该如何快速入门,这让人挺挣扎的.在从事数据科学的人中,最常用的工具就是R和Python ...

  7. C#中using语句是什么意思

    使用using语句最终生成的其实是一个try, finally代码块,在finally代码块里释放资源.要求是:为 using 语句提供的对象必须实现 IDisposable 接口.此接口提供了 Di ...

  8. 根据mysql数据库 定义solr Schema.xml中配置业务域

    <!--product--> <field name="product_name" type="text_ik" indexed=" ...

  9. 【Vue】vue的双向绑定原理及实现

    vue数据双向绑定是通过数据劫持结合发布者-订阅者模式的方式来实现的,那么vue是如果进行数据劫持的,我们可以先来看一下通过控制台输出一个定义在vue初始化数据上的对象是个什么东西. 代码: var ...

  10. ofbiz webservice 例解

    1.定义controller.xml文件,controller文件:ofbiz当前项目的所有请求的入口,通过对应request-map:将所有的请求uri对应到指定的处理函数上. <reques ...