前言:以前也经常用flex布局,但是最近看到别人使用的时候,发觉以前自己还是不够理解这个,重新看了一遍http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

一、Flex 布局是什么?

Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供很大灵活性。

所有容器都可以指定为flex布局

.box{
display: flex;
}

行内元素也可以

.box{
display:inline- flex;
}

如果是Webkit 内核的浏览器,加上-webkit前缀

.box{
display: -webkit-flex; /* Safari */
display: flex;
}

ps:设为 Flex 布局以后,子元素的floatclearvertical-align属性将失效。

二、基本概念

采用 Flex 布局的元素,称为 Flex 容器(flex container),简称"容器"。其他概念我就不详述了。

三、容器的属性

以下6个属性设置在容器上。

flex-direction
flex-wrap
flex-flow
justify-content
align-items
align-content

flex-direction属性

flex-direction属性决定主轴的方向(即项目的排列方向)。

.box {
flex-direction: row | row-reverse | column | column-reverse;
}
row(默认值):主轴为水平方向,起点在左端。
row-reverse:主轴为水平方向,起点在右端。
column:主轴为垂直方向,起点在上沿。
column-reverse:主轴为垂直方向,起点在下沿。

flex-wrap属性

.box{
flex-wrap: nowrap | wrap | wrap-reverse;
} nowrap(默认):不换行
wrap:换行,第一行在上方。
wrap-reverse:换行,第一行在下方。

flex-flow

flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。
.box {
flex-flow: <flex-direction> || <flex-wrap>;
}

justify-content属性

.box {
justify-content: flex-start | flex-end | center | space-between | space-around;
}
  • flex-start(默认值):左对齐
  • flex-end:右对齐
  • center: 居中
  • space-between:两端对齐,项目之间的间隔都相等。
  • space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍

 align-items属性

.box {
align-items: flex-start | flex-end | center | baseline | stretch;
}
  • flex-start:交叉轴的起点对齐。
  • flex-end:交叉轴的终点对齐。
  • center:交叉轴的中点对齐。
  • baseline: 项目的第一行文字的基线对齐。
  • stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。

 align-content属性

ps:align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。(跟上面一样)

.box {
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}
  • flex-start:与交叉轴的起点对齐。
  • flex-end:与交叉轴的终点对齐。
  • center:与交叉轴的中点对齐。
  • space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
  • space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
  • stretch(默认值):轴线占满整个交叉轴。

 项目属性(子元素上的)

order
flex-grow
flex-shrink
flex-basis
flex
align-self

order属性

ps:order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。

.item {
order: <integer>;
}

flex属性

flex属性是flex-growflex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。

.item {
flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
}

该属性有两个快捷值:auto (1 1 auto) 和 none (0 0 auto)。

建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值。

css3 flex属性flex-grow、flex-shrink、flex-basis学习笔记

最近在研究css3的flex。遇到的flex:;这一块,很是很纠结,flex-grow、flex-shrink、flex-basis始终搞不清,最经搜集了大量的介绍,应该能算是明白了。
网上大部分解释是
flex-grow 是扩展比率
flex-shrink 是收缩比率
flex-basis 伸缩基准值 假设flex盒子父级宽度固定为800px; Flex-grow、Flex-shrink、Flex-basis 是Flex属性的分写模式; 如
.box {
flex: 100px;
}
等于
.box {
flex-grow: ;
flex-shrink: ;
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(){
flex: 200px;
}
.flex-son:nth-child(){
flex: 300px;
}
.flex-son:nth-child(){
flex: 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)/加权值) * 溢出值 所以最后的加权值是
* + * + * = 2300px son1的扩展量:( * / ) * ,即约等于17px;
son2的扩展量:( * / ) * ,即约等于52px;
son3的扩展量:( * / ) * ,即约等于130px; 最后son1、son2、son3,的实际宽度为:
– = 184px;
– = 248px;
– 1 = 370px;

第二种情况
上面的例子已经说明,继续看第二个例子,同样上面的例子,我们改下父级宽度为1200px;
flex-basis的总和为 1000px,小于父级宽度,将有200px的剩余宽度;
既然有剩余,我们就不要加权计算,剩余的宽度将根据flex-grow,值得总和进行百分比,那么200px就会根据份数比来分配剩余的空间; 剩余后宽度 w = (子元素flex-grow值 /所有子元素flex-grow的总和) * 剩余值 总分数为 total = + + ; son1的扩展量:(/total) * ,即约等于100px;
son2的扩展量:(/total) * ,即约等于67px;
son3的扩展量:(/total) * ,即约等于33px; 最后son1、son2、son3,的实际宽度为:
+ = 300px;
+ = 367px;
+ = 533px; 总结 所以以上两种情况下,第二种flex-basis和flex-shrink是不列入计算公式的;第一种flex-grow是不列入计算公式的 ok,上面的两种情况总结完毕,但是很多时候我们的父级是不固定的,那么怎么办,其实很简单了,对照上面的公式,前提是已经设置了flex-basis值得元素,如果宽度的随机值小于flex-basis的时候就按第一种计算,反之第二种;明白了吧。 但是在实际中,我们有些子元素不想进行比例分配,永远是固定的,那么flex就必须设置为none;
否则设置的宽度(width)将无效; flex: , 则其计算值为 flex: %;
flex: auto, 则其计算值为 flex: auto;
flex: none, 则其计算值为 flex: auto; 根据上面的公式
flex:1的时候第一种方式其实是无效的,因为加权值是0,所以只能是第二种方式计算;
flex:none的时候,两种都失效,自己元素不参与父级剩余还是溢出的分配,flex:none的应用场景还是很多的;

ps:剩下属性就不讲了,大家可以去http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

Flex 布局的教程的更多相关文章

  1. 【转】Flex 布局语法教程

    网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 ...

  2. CSS布局-flex布局入门教程

    前言 2009年,W3C 提出了一种新的方案----Flex 布局,可以简便.完整.响应式地实现各种页面布局.目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能. 查询兼容 F ...

  3. Flex 布局语法教程

    一.Flex布局是什么? Flex是Flexible Box的缩写,翻译成中文就是“弹性盒子”,用来为盒装模型提供最大的灵活性.任何一个容器都可以指定为Flex布局. .box{ display: - ...

  4. flex布局基本语法

    注 : 本文章按照菜鸟教程 Flex布局语法教程为原型稍加修改,以方便自己学习. 菜鸟教程地址:http://www.runoob.com/w3cnote/flex-grammar.html 2009 ...

  5. 30分钟彻底弄懂flex布局

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由elson发表于云+社区专栏 目前在不考虑IE以及低端安卓机(4.3-)的兼容下,已经可以放心使用flex进行布局了.什么是flex布 ...

  6. Flex布局(CSS Flexbox)

    参考:Flex 布局语法教程 Flex布局是什么? Flex是Flexible Box的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性. 任何一个容器都可以指定为Flex布局 注意:设为Fle ...

  7. flex布局学习总结

    最近项目主要是小程序,小程序里面的布局主要采用flex布局,之前对flex 布局只是稍作了解,总结下flex 布局的常用套路 容器 Flex是Flexible Box的缩写,意为"弹性布局& ...

  8. 弄懂flex布局

    目前在不考虑IE以及低端安卓机(4.3-)的兼容下,已经可以放心使用flex进行布局了.什么是flex布局以及它的好处,这里就不再赘述. 在这篇文章里,想说说flex布局的属性语法及其细节.那么网上也 ...

  9. 30 分钟学会 Flex 布局

    30 分钟学会 Flex 布局 有酒   617 人赞同了该文章 为什么我要写这一篇关于 Flex 布局的教程? 因为它十分简单灵活,区区简单几行代码就可以实现各种页面的的布局,以前我在学习页面布局的 ...

随机推荐

  1. Codeforces1099D.Sum in the tree(贪心)

    题目链接:传送门 思路: 一个节点放的数越大,那么以它为根的子树的节点权值之和就越小. 所以我们要在合法的范围内,使偶数层节点的权值尽可能地大.也就是说,令它的权值是子节点的最小值,这样保证了它的子节 ...

  2. Java基于opencv实现图像数字识别(五)—投影法分割字符

    Java基于opencv实现图像数字识别(五)-投影法分割字符 水平投影法 1.水平投影法就是先用一个数组统计出图像每行黑色像素点的个数(二值化的图像): 2.选出一个最优的阀值,根据比这个阀值大或小 ...

  3. JDK无法卸载问题解决

    在控制面板卸载JDK时,显示正在收集删除文件,进度条满了之后就闪退了,但JDK还在,试了几次都是如此. 后来,发现微软官方出了“修复阻止程序安装或删除的问题”的应用,可以自动修复包括阻止你安装或删除程 ...

  4. Python 虚拟环境[virtualenv/virtualenvwrapper]设置

      virtualenv virtualenv 是一个可以在同一计算机中隔离多个python版本的工具.有时,两个不同的项目可能需要不同版本的python,如 python2.6.6 / python ...

  5. [Java Web学习]JDBC事务处理

    1. Spring中加入数据库的bean <bean id="dataSource" class="org.apache.commons.dbcp.BasicDat ...

  6. 安装grub到U盘分区,实现多系统引导

    目录 1.分区工具及分区类型 1.1 显示分区表和分区信息 1.1.1 fdisk -l 1.1.2 gdisk -l 1.1.3 parted -l 1.2 常见分区类型 1.3 分区样例 1.3. ...

  7. 2018-2019-2 20165313 《网络对抗技术》 Exp5:MSF基础应用

    实践使用漏洞和辅助模块 任务一:MS17-010安全漏洞 任务二:(1)MS11-050(失败)(2)MS14-064(唯一) 任务三:abode_flash_avm2 辅助模块:(1)ARP扫描模块 ...

  8. SP3871 GCDEX - GCD Extreme

    //author Eterna #define Hello the_cruel_world! #pragma GCC optimize(2) #include<iostream> #inc ...

  9. Actifio如何保护和管理Oracle-带外篇

    引言 本文提供CDS带外环境下相关配置,保护和恢复Oracle的所需步骤. 目的是提供Oracle数据库配置前的详细说明,Actifio环境下发现和配置Oracle数据库,执行还原和恢复,以及配置Or ...

  10. visual studio 2017 中默认无法开发 Android 8.0 及以上系统的解决方案

    一般默认比较旧有两个原因,系统版本过旧,Visual Studio 版本过旧. 第一步,将windows 更新到最新版,必须是windows 10 并且更新到最新. 第二步,将visual studi ...