前端布局之Flex语法
来源:互联网 发布:网络营运商 编辑:程序博客网 时间:2024/05/22 10:56
前端布局一直是CSS的一个重点应用,然而基于盒子模型的传统布局方案,依赖display
+ position
+ float
属性,对于某些特殊的布局非常不方便,比如:垂直居中就不容易实现。针对这一情况,在2009
年,W3C
提出了一种新的方案:Flex
布局,可以简便、完整、响应式地实现前端的各种布局,并且已经得到几乎所有浏览器的支持。
众所周知,前端分为PC
端和移动端,并且它们的界面布局有一些差别,比如:PC
端的界面中,水平方向是主轴(main axis
),竖直方向是交叉轴(cross axis
);而移动端,水平方向是交叉轴(cross axis
),竖直方向是主轴(main axis
),针对这一差别,在前端布局中要特别注意。
flex属性简介
flex
的属性分为两类:父容器属性和子item
的属性
父容器属性
子item属性
Flex布局
Flex
是Flexible Box
的缩写,意思是弹性布局,用来为盒子模型提供最大的灵活性。分为两种布局方式:flex
和 inline-flex
。
1. flex: 将对象作为弹性伸缩盒显示
flex
默认从左边开始布局,所以指定宽度后,子item
就开始从左至右依次布局
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Test</title> <style type="text/css"> .main{ width:200px; background-color: red; display: flex;/*父div设置该属性*/ } .main>div{ width: 50px; height: 50px; border: 1px solid blue; box-sizing: border-box;/*这是css3属性,如果不懂,请继续往下阅读*/ /*float:left;这个属性就不需要了,会自动浮动*/ } </style></head><body> <div class="main"> <div>1</div> <div>2</div> <div>3</div> <div>4</div> </div></body></html>
效果图
2. inline-flex:将对象作为内联块级弹性伸缩盒显示
inline-flex
将对象作为内联级容器,它会根据子item
的大小自适应宽度和高度,所以可以删除width: 200px
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Test</title> <style type="text/css"> .main{ background-color: red; display: inline-flex;/*父div设置该属性*/ } .main>div{ width: 50px; height: 50px; border: 1px solid blue; box-sizing: border-box;/*这是css3属性,如果不懂,请继续往下阅读*/ /*float:left;这个属性就不需要了,会自动浮动*/ } </style></head><body> <div class="main"> <div>1</div> <div>2</div> <div>3</div> <div>4</div> </div></body></html>
效果图
flex父容器属性
1. flex direction
控制主轴的方向,即子item
的排列方向,有四个取值范围:
- row(default)- 主轴水平
- row-reverse
- column - 主轴垂直
- column-reverse
2. flex wrap
定义子item
在主轴方向的换行效果
3. flex-flow
该属性是flex-direction
和flex-wrap
两个属性的缩写,默认值为:row nowrap
4. justify content
定义子item
在主轴方向的对齐方式
5. align-items
定义子item
在交叉轴方向的对齐方式
6. align-content
定义多行子item
在交叉轴上的对齐方式
子item属性
1. order
定义子item
的排列顺序,默认为0
2. flex-grow
定义子item
的宽度小于父容器时,子item
的拉伸比例,默认为0
,表示不拉伸
3. flex-shrink
定义子item
的宽度之和超过父容器时,子item
的缩放的比例,默认为1
4. flex-basis
设置子item的宽度(flex-direction = row
)或高度(flex-direction = column
)。如果设置该属性,那么flex-grow/flex-shrink
以该属性大小进行缩放
5. flex
该属性是:flex-grow flex-shrink flex-basis
的简写,默认值为:0 1 auto
,其中后两个属性可选
6. align-self
定义单个子item
在交叉轴上的对齐方式,会覆盖默认的对齐方式。默认值为auto
,表示继承父容器的align-items
属性,如果没有父容器,则等同于stretch
(stretch
: 伸缩项目在交叉轴方向占满伸缩容器, 前提是不设置交叉轴方向的尺寸)
定位
display
属性定义子item
如何在父容器内布局,有两中类型:relative
和 absolute
1. display: relative
在相对定位中,布局子item
时需要用到margin
、border
、padding
等盒子模型。其中,border
和padding
会显示在item的背景色中;而margin
则不会,默认是透明色
2. display: absolute
使用绝对定位的item
,如果其父容器设置了relative
布局,则以父容器做参考,如果父容器不设置relative
布局,则以window
做参考。其中,设置布局的属性为:left、right、top、bottom、start、end
。
Position = Absolute; Start = 0; Top = 0; Width = 50; Height = 50;
视图:
Position = Absolute; Start = 10; Top = 10; End = 10; Bottom = 10;
视图:
至此,Flexbox的语法介绍完毕,虽然有点多,但是还要多练,熟能生巧,熟练后你会发现,前端flex布局快速、高效和灵活。
(部分图片来源互联网,如有侵权,请告知,我怕赔不起)
参考文章
https://www.w3.org/TR/css-flexbox-1/#flex-formatting-context
https://facebook.github.io/yoga/docs/absolute-position/
http://www.cnblogs.com/shuiyi/p/5716918.html
http://www.w3school.com.cn/css/css_boxmodel.asp
http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html
https://my.oschina.net/sheila/blog/384806
- 前端布局之Flex语法
- 前端 flex弹性布局之弹性布局中文换行
- Flex 布局语法教程
- Flex 布局:语法篇
- flex布局语法
- flex布局教程:语法
- flex布局语法篇
- Flex 布局语法教程
- Flex 布局教程:语法
- Flex 布局语法教程
- flex布局语法详解
- Flex布局语法简介
- flex布局语法教程
- CSS学习之Flex弹性布局语法介绍
- Flex 布局基础语法篇
- Flex 布局教程:语法篇
- Flex 布局教程:语法篇
- Flex 布局教程:语法篇
- CodeForces 359 D.Pair of Numbers (二分+ST)
- Depth First Search (DFS) | Iterative & Recursive Implementation
- 数据采集(二):腾讯新闻网,新闻标题和内容爬取
- java.concurrent包常见类详解
- 主流手机分辨率
- 前端布局之Flex语法
- JVM的内存模型
- 微服务的优缺点
- centos 配置php环境-apache,mysql5.6,php5.6环境过程分享
- linux之sed的用法
- 5.7版本mysql中localhost和%的关系探究
- 菜鸟上路-运算符-复习
- Xilinx加法器IP核adder
- HTML5 body设置全屏背景图片 如何让body的背景图片自适应整个屏----实战经验