详解CSS的Flex布局
本文由云+社区发表
Flex是Flexible Box 的缩写,意为"弹性布局",是CSS3的一种布局模式。通过Flex布局,可以很优雅地解决很多CSS布局的问题。下面会分别介绍容器的6个属性和项目的6个属性。每个属性会附上效果图,具体实现代码会以github路径形式更新于此。
1.浏览器支持情况
可以点击查看各浏览器的兼容情况
2.容器的属性
注意,设为 Flex 布局以后,子元素的float、clear和vertical-align属性将失效。
容器的属性有6个,分别是:
flex-direction
flex-wrap
flex-flow
justify-content
align-items
align-content
(1)flex-direcion属性:
作用:控制主轴的方向
flex-direction: row | row-reverse | column | column-reverse;
默认值:row
(2)flex-wrap属性:
作用:默认情况下,项目都排在一条线(又称"轴线")上。flex-wrap属性定义,如果一条轴线排不下,如何换行。
flex-wrap: nowrap | wrap | wrap-reverse;
默认值:nowrap
(3)flex-flow属性
作用:该属性是flex-direction属性和flex-wrap属性的简写形式
默认值:row nowrap
(4)justify-content属性
作用:定义项目在主轴上的对齐方式
justify-content: flex-start | flex-end | center | space-between | space-around;
默认值:flex-start
(5)align-items属性
作用:定义项目在交叉轴上如何对齐。
align-items: flex-start | flex-end | center | baseline | stretch
默认值:flex-start
注意:如果align-items为stretch,想看到每个flex-item铺满整个交叉轴的话,需要设置所有的flex-item的高度:height:auto,否则达不到效果。
(6)align-content属性
属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
默认值:stretch
flex-start:与交叉轴的起点对齐。
flex-end:与交叉轴的终点对齐。
center:与交叉轴的中点对齐。
space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
stretch:轴线占满整个交叉轴。
3.项目的属性
项目的属性有6个,分别是:
order
flex-grow
flex-shrink
flex-basis
flex
align-self
(1)order属性:
作用:定义项目的排列顺序,数值越小,排列越靠前。
默认值:0
(2)flex-grow属性
作用:如果存在剩余空间,项目放大的比例。相当于是各个项目根据这个比例,来分配剩余空间。
默认值:0(不放大)
(3)flex-shrink属性
作用:flex-shrink:如果存在空间不足,项目的“缩小比例”。0表示当空间不足时,不缩小。
默认值:1
负值对该属性无效
(4)flex-basis属性
作用:定义项目在主轴方向上占据空间大小的初值。
默认值:auto(项目本来的大小)
(5)flex属性
作用:是flex-grow、flex-shrink、flex-basis属性的缩写形式;
flex: none | [<'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
注:几种常见缩写形式;
flex: auto; === flex: 1 1 auto;
flex: none; === flex: 0 0 auto;
flex: initial; === flex: 0 1 auto;
flex: ; === flex: 1 auto;
flex: 1; === flex: 1 1 auto;
建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值
(6)align-self属性
作用:属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。
align-self: auto | flex-start | flex-end | center | baseline | stretch;
默认值:auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。
4.小结
本文分别介绍了容器的6个属性和flex-item项目的6个属性。建议跟着demo整体做一遍,有助于加深理解。如有问题,欢迎指正。
此文已由作者授权腾讯云+社区发布
详解CSS的Flex布局相关推荐
- float属性html,详解CSS样式中的float属性
详解CSS样式中的float属性.float是 css 样式的定位属性.我们在印刷排版中,文本可以按照需要围绕图片.一般把这种方式称为"文本环绕".在网页设计中,应用了CSS的fl ...
- 详解CSS的盒模型(box model) 及 CSS3新增盒模型计算方式box-sizing
W3C规范 一般来说,页面中的每一个元素都会形成一个矩形盒子,渲染引擎根据给定的样式确定这个盒子的呈现.通俗的来说,页面的布局就是一个个盒子的排列和摆放.掌握了盒子呈现的本质,布局也就轻而易举. 在 ...
- inline-block是html5,详解CSS display:inline-block的应用
本文详细描述了display:inline-block的基础知识,产生的问题和解决方法以及其常见的应用场景,加深了对inline-block应用的进一步理解. 基础知识 display:inline- ...
- 详解CSS display:inline-block的应用(转)
详解CSS display:inline-block的应用 阅读目录 基础知识 inline-block的问题 inline-block的应用 总结 本文详细描述了display:inline-blo ...
- html nthchild作用,详解CSS中:nth-child的用法
前端的哥们想必都接触过css中一个神奇的玩意,可以轻松选取你想要的标签并给与修改添加样式,是不是很给力,它就是":nth-child". 下面我将用几个典型的实例来给大家讲解:nt ...
- 详解CSS float属性
转自:http://luopq.com/2015/11/08/CSS-float/ \详解CSS float属性 Posted on 2015-11-08 | In CSS | 5条评 ...
- qt布局嵌套_QDockWidget嵌套布局详解-实现Visual Studio布局
概述 许多工程软件,如Qt Creator,VS,matlab等,都是使用dock布局窗口,这样用户可以自定义界面,自由组合窗口. Qt的嵌套布局由QDockWidget完成,用Qt Creator拖 ...
- html css 距离顶部距离,详解CSS line-height和height
最近在做CSS界面时经常遇到line-height和height这两个属性,一直没搞很明白,今天静下心来好好网上查阅了一下,算是有所领悟.https://blog.csdn.net/a20131263 ...
- CSS 之 Flex布局
CSS 之 Flex布局 文章目录 CSS 之 Flex布局 1.Flex布局 vs 网格布局 (1D vs 2D) 2.Flex属性 1)flex-direction属性 & 排列方向 2) ...
最新文章
- 逆天改命,机械飞升:渐冻症科学家拒绝等死,将自己改造成了「半机械人」...
- 【转】测试LibreOffice SDK 开发环境配置(Windows)
- native react 更新机制_深度使用react-native的热更新能力,必须知道的一个shell命令...
- Ubuntu下 Oracle sqldeveloper中文目录、文件,select查询结果中:中文乱码
- Oracle啟動模式關閉模式
- bottle中文文档
- Visual Studio 2010/2013 UTF8编码调试时显示中文
- mariadb mysql 语法_Mariadb MySQL、Mariadb中GROUP_CONCAT函数使用介绍
- caioj1522: [NOIP提高组2005]过河
- 【转】Java中的关键字 transient
- TOP公链主网技术:多层扩容和多层分片
- ps4移植android游戏,把PS4游戏《Apex英雄》《只狼》搬到安卓手机上玩,这招够简单!...
- Spark集群运行xgboost4j-spark总结
- WebEx如何录制电脑内的声音
- android打开app白色页面,完美解决Android App启动页有白屏闪过的问题
- handler中的handler.removecallbacks和handler.removemessages的用法
- 最大子序列之和(C语言)
- 【读书笔记《凤凰架构》- 构架可靠的大型分布式系统.周志明】(一)
- 606. 根据二叉树创建字符串C++
- App上架到各大安卓应用***流程
热门文章
- 机场精细化管理_全国首家!西安咸阳国际机场通过民航局安全管理体系专项审核...
- oracle 获取日期年份
- EasyUI中combotree 研究
- 智能一代云平台(二十四):已安装的Nginx上安装echo插件
- Eclipse启动项目报启动上下文失败问题解决方案总结
- 康奈尔机器人的肌肉是爆米花做的,果然很有爆发力 | ICRA 2018
- 从应届技术男到百度VP,这是低调到没百科的吴海锋首次受访
- 盖茨买下一座城,想建成沙漠中的智慧城市
- IntelliJ IDEA字符串常量长度太长的问题解决:constant string too long
- EBS_FORM_开发:关于切换不同BLOCK的时候弹出需要保存的窗口