flex布局

  用以代替浮动的布局手段;

  必须先把一个元素设置为弹性容器;//display:flex;

  一个元素可以同时是弹性容器和弹性元素;

  设为flex布局以后,子元素的float、clear和vertical-align属性将失效。

  主轴:弹性元素排列的方向;

弹性容器的属性

1、flex-direction 决定主轴的方向

  row:默认值,从左到右;

  row-reverse:从右到左;

  column:从上到下;

  column-reverse:从下到上;

2、flex-wrap 决定是否换行

  nowrap:默认值,不换行;

  wrap:换行,第一行在上方;

  wrap-reverse:换行,第一行在下方;

3、flex-flow

  flex-direction和flex-wrap的简写形式,默认值是row nowrap;

  //flex-flow: row wrap;

4、 justify-content 决定弹性元素在主轴上的对齐方式

  flex-start:默认值,左对齐;

  flex-end:右对齐;

  enter: 居中;

  space-between:两端对齐,弹性元素之间的间隔都相等(两侧的弹性元素与边框没有距离);

  space-around:每个弹性元素两侧的间隔相等(弹性元素之间的间隔比弹性元素与边框的间隔大一倍)

5、align-items 决定子元素如何在父盒子中垂直对齐(单行)

  flex-start:沿辅轴的起点对齐,从起点一直排向(带箭头的)终点;

  flex-end:沿辅轴的终点对齐,从终点一直排向起点;

  center:居中对齐;

  baseline: 基线对齐;

  stretch:默认值,让子元素拉伸以适应父元素(子元素不给高度的前提下);

6、align-content 决定多行垂直对齐的情况(对单行无效)

  该属性生效的条件:

  必须对父元素设置自由盒属性//display:flex;

  并且设置排列方式为横向排列//flex-direction:row;

  并且设置换行//flex-wrap:wrap;

  属性值:

    1)stretch:默认值,会拉伸容器内每一行的占用的空间,填充方式为给每一行的下方增加空白;

      第一行默认从容器顶端开始排列。

    2)取消行与行之间的空白并把所有行作为一个整体,

      center:在纵轴上垂直居中;

      flex-start:放在容器的顶部;

      flex-end:放在容器的底部;

    3)space-between:上面的行对齐容器顶部,最下面行对齐容器底部。留相同间隔在每个行之间。

      (对齐就是贴紧,没有留空隙);

       space-around:每一行的上下位置保留相同长度空白,使得行之间的空白为两倍的单行空白。

弹性元素的属性

1、order 决定子元素的排序

  数值越小越往前,可为负,默认为零;//order:1;

2、 flex-grow

  决定子元素的伸展系数,在父元素的剩余空间中按比例分配;//flex-grow :1;

  如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话);

  如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。

3、flex-shrink

  决定子元素的收缩系数,当父元素的空间不足以容纳所有子元素;//flex-shrink :1;

  如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小;

  如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。

4、flex-basis

  指定的是子元素在主轴的基础长度;

  若主轴为横向,则该值指定的是宽度,即纵向指定的是高度;

  默认值是auto,表示参考元素自身的宽/高,有传具体数值则以该值为准;

5、flex :增长 缩减 基础

  flex-grow 、flex-shrink 、flex-basis的简写属性;

  initial --- flex: 0 1 auto;

  auto --- flex: 1 1 auto;

  none --- flex: 0 0 auto;弹性元素没有弹性,不缩不减;

6、align-self

  允许单个子元素有与其他子元素在纵轴上不一样的对齐方式,可覆盖align-items属性;

  默认值为auto,表继承父元素的align-items属性,如果没有父元素,就等同于stretch

  属性值: auto 、flex-start 、 flex-end 、 center 、baseline 、 stretch;

//花了两个小时整理,对我来说挺有用的,越是难点越要突破,一起加油叭,冲冲冲!!

flex布局你真的搞懂了吗?通俗简洁,小白勿入~的更多相关文章

  1. 你真的搞懂了Java中的<<、>>、>>>运算符嘛?

    在搞懂<<.>>.>>>之前,我们需要先了解二进制中的源码.反码.补码... 二进制中的原码.反码.补码 有符号数: 对于有符号数而言,符号的正.负机器是无法 ...

  2. Flex属性你真的搞清楚了吗?我深表怀疑

    背景 在使用弹性布局实现两侧宽度固定,中间宽度自适应的效果时,发现自己理解的和实际效果不一致,所以亲自实践验证了一个flex属性的诸多场景的表现,不仅解开了我之前使用过程遇到的疑惑,而且发现了许多自己 ...

  3. 你真的搞懂ES6模块的导入导出规则了吗

    前言 模块作为ES6规范的核心部分之一,在实际项目开发中经常会看到它的身影,那么我们是否真正了解它的相关规则呢,今天就带大家一起了解一下模块的导入导出规则 导入 ES6模块的导入(即import)大致 ...

  4. 别再人云亦云了!!!你真的搞懂了RDD、DF、DS的区别吗?

    几年前,包括最近,我看了各种书籍.教程.官网.但是真正能够把RDD.DataFrame.DataSet解释得清楚一点的.论据多一点少之又少,甚至有的人号称Spark专家,但在这一块根本说不清楚.还有国 ...

  5. 小伙子,你真的搞懂 transient 关键字了吗?

    先解释下什么是序列化 我们的对象并不只是存在内存中,还需要传输网络,或者保存起来下次再加载出来用,所以需要Java序列化技术. Java序列化技术正是将对象转变成一串由二进制字节组成的数组,可以通过将 ...

  6. 晨叔技术晨报: 你真的搞懂JS中的“值传递”和“引用传递”吗?

    晨叔周刊,每周一话题,技术天天涨. 本周的话题是JS的内存问题(加入本周话题,请点击传送门). 图 话题入口 今天的技术晨报来,就来谈谈JS中变量的,值传递和引用传递的问题.现在,对于很多的JSer来 ...

  7. 彻底搞懂flex弹性盒模型布局

    为什么要用flex 基于css3简单方便,更优雅的实现,浏览器兼容性好,传统的css实现一个div居中布局要写一堆代码,而现在几行代码就搞定了,没有理由不用flex. 兼容性: Base Browse ...

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

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

  9. 弄懂flex布局

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

随机推荐

  1. 用vue + leancloud开发一个免费的博客

    项目地址 https://github.com/Fee-ing/Fe... 在线预览 在线预览地址: 搭建免费博客

  2. Java基础篇(02):特殊的String类,和相关扩展API

    本文源码:GitHub·点这里 || GitEE·点这里 一.String类简介 1.基础简介 字符串是一个特殊的数据类型,属于引用类型.String类在Java中使用关键字final修饰,所以这个类 ...

  3. Apache Druid 的集群设计与工作流程

    导读:本文将描述 Apache Druid 的基本集群架构,说明架构中各进程的作用.并从数据写入和数据查询两个角度来说明 Druid 架构的工作流程. 关注公众号 MageByte,设置星标点「在看」 ...

  4. jwt的token如何使用

    JWT简介: JWT(JSON WEB TOKEN):JSON网络令牌,JWT是一个轻便的安全跨平台传输格式,定义了一个紧凑的自包含的方式在不同实体之间安全传输信息(JSON格式).它是在Web环境下 ...

  5. 「从零单排HBase 04」HBase高性能查询揭秘

    先给结论吧:HBase利用compaction机制,通过大量的读延迟毛刺和一定的写阻塞,来换取整体上的读取延迟的平稳. 1.为什么要compaction 在上一篇 HBase读写 中我们提到了,HBa ...

  6. airtest的使用(作用类似于appium)

    1.安装 下载免安装版本:http://airtest.netease.com/ 文档:http://airtest.netease.com/docs/docs_AirtestIDE-zh_CN/in ...

  7. net core天马行空系列:移植Feign,结合Polly,实现回退,熔断,重试,超时,做最好用的声明式http服务调用端

    系列目录 1.net core天马行空系列:原生DI+AOP实现spring boot注解式编程 2.net core天马行空系列: 泛型仓储和声明式事物实现最优雅的crud操作 3.net core ...

  8. Qt5小Demo之猜数字游戏

    玩法:设定时间进行猜数字,所猜数字为一个四位数,输入自己的数字,系统会提示是大了还是小了,依据条件逐步逼近正确结果.在规定时间里猜对即获胜,否则即失败. 平台支持:Win10下测试正常. 源码地址: ...

  9. GoJS学习笔记 (转)

    目录 基础概念 开始绘制图形 1. 通过代码构建图形 2. 通过 GraphObject.make 构建图形 3. 使用 Model 和 Templates 创建图形 获取图形数据 获取所有 Node ...

  10. C# RSACryptoServiceProvider 加密解密 RSA 加密解密

    什么是RSA:RSA公开密钥密码体制.所谓的公开密钥密码体制就是使用不同的加密密钥与解密密钥,是一种“由已知加密密钥 推导出 解密密钥在计算上是不可行的”密码体制. 下附代码,在控制台中粘贴在启动类即 ...