前言:以前也经常用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. Oracle数据库:ORA-54013错误解决办法

    ORA-54013: 不允许对虚拟列执行 INSERT 操作 这是Oracle 11 的新特性 —— 虚拟列. 在以前的Oracle 版本,当我们需要使用表达式或者一些计算公式时,我们会创建数据库视图 ...

  2. 关于java的scanner类

    java.util.Scanner 是 Java5 的新特征,我们可以通过 Scanner 类来获取用户的输入. 首先使用Scanner类时候需要导包: scanner类的基本语法: Scanner类 ...

  3. python 内置函数 进制转换

    4.内置函数 自定义函数 内置函数 len Open id() type() range() 输入输出 print() input() 强制转换 int() float() list() tuple( ...

  4. PAT乙级考前总结(二)

    简单模拟 1002 写出这个数 (20 分) 1006 换个格式输出整数 (15 分) 又是数数 1016 部分A+B (15 分) 相当于找数字 1018 锤子剪刀布 (20 分) 题目略 此处用了 ...

  5. adv生成控制器手腕位置倾斜原因以及解决方案

    系统默认问题导致手腕倾斜详情描述: 手腕部分默认生成轴向是冲向模板下一层级第一个物体  简单说就是 FK轴向冲向模板中指方向 如图 默认模板没问题是因为  默认模板没有改动情况下系统中指与手腕在一条直 ...

  6. Netty 线程模型

    一.线程模型概述 线程模型表明了代码的执行方式.从最开始的使用单线程,后来出现了多线程,之后是线程池.当有要执行的任务时,任务会被传到线程池,从线程池中获得空闲的线程来执行任务,执行完了后会将线程返回 ...

  7. React Native 开发环境搭建

    1.安装 Python 2,不知道是否已支持 Python 3 2.安装 node,npm... 修改 npm 镜像,不建议使用 cnpm,cnpm 安装模块的路径与 npm 有差别 npm conf ...

  8. iPhone / iPad L2TP Client Setup

    原文链接:http://www.softether.org/4-docs/2-howto/9.L2TPIPsec_Setup_Guide_for_SoftEther_VPN_Server/2.iPho ...

  9. 解决openstack实例主机名后缀问题

    参考地址https://ask.openstack.org/en/question/26918/change-novalocal-suffix-in-hostname/ 问题现象 可以看到主机名的后缀 ...

  10. Gradle的使用及下载

    1在官网下载Gradle 基本学这个的都有JDK和JVM所以只需要在环境变量中配置即可 点击hettp://start.spring.io/即可使用