探讨弹性布局Flexible Box
早之前有所了解,现在有时间整理一下,跟大家分享学习。
虽然Flex布局09年就被W3C所提出,但是目前浏览器支持上还不是很好,网上找的一张图片,仅供参考:

我们先从简单讲起。如果仅仅只想实现一个栅格布局,没必要引入一个复杂的框架(如bootstrap),短短几行代码也能实现该功能。
例子:有个父div,三个子div,宽度比是1:2:1,以下代码:
<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
* {
box-sizing: border-box;
}
body {
padding: 20px;
}
.flex{
display:flex;
}
.flex div{
text-align: center;
}
.one{
background: blue;
flex:1;
}
.two{
flex:2;
background: yellow;
}
</style>
</head>
<body>
<div class="flex">
<div class="one">one</div>
<div class="two">two</div>
<div class="one">one</div>
</div>
</body>
</html>
显示如下:

解读:把父div设置为display:flex;后,它的所有子元素自动成为容器成员。同时,所有的子元素的float、clear、vertical-align都会失效。子元素有个属性flew,其实接受的是3个值,分别是flex-grow,flex-shrink,flex-basis,后两个属性选填(这里用不上便不填,后面再做介绍),flex-grow:定义当前子元素的比例。
Q:如果我想要列与列之间有等距间隔怎么办?
A:你可以添加 margin 到列上。你也可以添加 padding 到列上。当然父div有个宽度补齐(justification)的属性也可以实现。
代码稍作修改:
<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
* {
box-sizing: border-box;
}
body {
padding: 20px;
}
.flex{
display:flex;
justify-content: space-between;
}
.flex div{
text-align: center;
}
.one{
background: blue;
width: 23%;
}
.two{
background: yellow;
width:48%;
}
</style>
</head>
<body>
<div class="flex">
<div class="one">one</div>
<div class="two">two</div>
<div class="one">one</div>
</div>
</body>
</html>
显示如下:

解读:稍作介绍下justify-content属性。它定义子元素在主轴上的对齐方式,一共有5个值:
flex-start(默认值):左对齐

flex-end:右对齐

center:居中

space-between:两端对齐,子元素之间的间隔都相等

space-around:每个子元素两侧的间隔都相等,所以就会形成子元素与子元素之间的间隔是子元素与两端之间的间隔的2倍

以上是一些简单的用法,下面想详细的记录下flex的其他用法,跟大家分享,不对之处请多多指出。
—————————————————————————————————分割线—————————————————————————————————————
将一个容器(为避免混淆,暂称父元素)设置display为flex后,父元素便拥有以下属性:
1、flex-direction:决定子元素的排列方向。
row: 默认值,水平方向排列,起点在左边。

row-reverse:水平方向排列,起点在右边。

column:垂直方向,起点在上沿。

column-reverse:垂直方向,起点在下沿。

2、flex-wrap:定义一行排不下时如何换行。
nowrap(默认):不换行。
wrap:换行,第一行在上方。
wrap-reverse:换行,第一行在下方。
3、flex-flow:flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。
4、justify-content:前面已经介绍,忘记了请往前看。
5、align-items:还记得flex-direction吗,这个属性类似于定义子元素在垂直方向上面的对齐方式。
先来段代码:
<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.flex{
display:flex;
width:200px;
height:200px;
background: #ccc;
margin:50px auto;
}
.flex div{
text-align: center;
}
.one{
background: blue;
flex:1;
}
.two{
background: yellow;
flex:2;
}
</style>
</head>
<body>
<div class="flex">
<div class="one"><p></p>one1</div>
<div class="two">two</div>
<div class="one">one2</div>
</div>
</body>
</html>
(此时子元素并没设置高度以及父元素没有设置align-items当然是按照默认值显示)
1)stretch(默认值):如果子元素未设置高度或设为auto,将占满整个容器的高度。

修改css
.flex{
display:flex;
width:200px;
height:200px;
background: #ccc;
margin:50px auto;
align-items:flex-start;
}
.one{
background: blue;
flex:;
height: 50px;
}
.two{
background: yellow;
flex:;
height: 100px;
}
2)flex-start:上沿对齐。

3)flex-end:下沿对齐。

4)center:居中对齐。

5)baseline: 子元素的第一行文字的基线对齐。

子元素有以下属性:
1、order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。
.one{
background: blue;
flex:;
order:;
}
.two{
background: yellow;
flex:;
}

2、flex-grow:定义当前子元素的比例,比如上面one比例是1,two比例是2。
3、flex-shrink:可选属性。属性定义了子元素的缩小比例,默认为1,即如果空间不足,该子元素将缩小。如果所有子元素的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个子元素的flex-shrink属性为0,其他子元素都为1,则空间不足时,属性为0的不缩小,负值对该属性无效。
4、flex-basis:可选属性。定义分配空间前,该子元素的宽度。默认值auto,可设置固定值(如100px),设置后该子元素将占据固定空间。
.flex{
display:flex;
width:200px;
height:200px;
background: #ccc;
margin:50px auto;
}
.one{
background: blue;
flex-basis:80px;
}
.two{
background: yellow;
flex:;
}

5、简写的flex属性。flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。
6、align-self:align-self属性允许单个子元素有与其他子元素不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。
<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.flex{
display:flex;
width:200px;
height:200px;
background: #ccc;
margin:50px auto;
align-items:center;
}
.one{
background: blue;
flex:1;
height: 50px;
}
.two{
background: yellow;
flex:2;
height: 100px;
align-self:flex-end;
}
.flex div{
text-align: center;
}
</style>
</head>
<body>
<div class="flex">
<div class="one">one1</div>
<div class="two">two</div>
<div class="one">one2</div>
</div>
</body>
</html>

———————————————————————————————分割线——————————————————————————————————
学以致用,我们来用Flex布局实现圣杯布局
要实现的效果:上中下三块,其中中间一块为左中右,左右等宽,中间占其余宽度。
<!DOCTYPE html>
<html>
<head>
<title></title>
<style>
*{
padding:0;
margin:0;
}
html,body{
width: 100%;
height: 100%;
}
.main{
width:100%;
height:100%;
display: flex;
flex-direction: column;
}
.header,.footer{
flex: 1;
background: yellow;
}
.middle{
flex: 5;
display:flex;
}
.center{
flex: 1;
background: #ccc;
}
.left,.right{
background:green;
flex: 0 0 100px;
}
.left{
order: -1;
}
</style>
</head>
<body>
<div class="main">
<div class="header"></div>
<div class="middle">
<div class="center"></div>
<div class="left"></div>
<div class="right"></div>
</div>
<div class="footer"></div>
</div>
</body>
</html>

分享完毕,欢迎转载,请注明出处!
参考链接:http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html?utm_source=tuicool
探讨弹性布局Flexible Box的更多相关文章
- 弹性布局 Flexible Box
页面中任何一个元素都可以指定为 弹性布局(Flex) 属性:display 取值: 1.flex 将块级元素变为弹性布局容器 2.inline-flex 将行内元素变为弹性布局容器 兼容性 ...
- CSS:CSS弹性盒子布局 Flexible Box
一.简介 flexbox:全称Flexible Box, 弹性盒子布局.可以简单实现各种伸缩性的设计,它是由伸缩容器和伸缩项目组成.任何一个元素都可以指定为flexbox布局.这种新的布局方案在200 ...
- 简单探讨弹性布局flex
css 弹性布局: 盒子模型: box-sizing属性1.content-box 正常的普通的盒子模型用padding和border会使盒子变大:(向外扩张)2.border-box 盒子模型,pa ...
- Flex box弹性布局 及 响应式前端设计的优化
Flex box弹性布局 Flex box是CSS3新添加的一种模型属性,它的出现有力的打破了我们常常使用的浮动布局.实现垂直等高.水平均分.按比例划分,可以实现许多我们之前做不到的自适应布局.如果你 ...
- css3 弹性布局和多列布局
弹性盒子基础 弹性盒子(Flexible Box)是css3中盒子模型的弹性布局,在传统的布局方式上增加了很多灵活性. 定义一个弹性盒子 在父盒子上定义display属性: #box{ display ...
- 第10章 布局样式相关-伸缩布局(Flexible Box)
伸缩布局(一) CSS3引入了一种新的布局模式--Flexbox布局,即伸缩布局盒模型(Flexible Box),用来提供一个更加有效的方式制定.调整和分布一个容器里项目布局,即使它们的大小是未知或 ...
- CSS3 Flex Box 弹性盒子、弹性布局
目录 1. 概要 2. justify-content 属性 3. align-items 属性 4. flex-wrap 属性 5. align-content 属性 6. 居中 7. align- ...
- CSS3弹性伸缩布局(一)——box布局
CSS3弹性伸缩布局简介 2009年,W3C提出了一种崭新的方案----Flex布局(即弹性伸缩布局),它可以简便.完整.响应式地实现各种页面布局,包括一直让人很头疼的垂直水平居中也变得很简单地就迎刃 ...
- CSS3伸缩盒Flexible Box
这是一种全新的布局,在移动端非常实用,IE对此布局的相关的兼容不是很好,Firefox.Chrome.Safrai等需要加浏览器前缀. 先说说这种布局的特点: 1)移动端由于屏幕宽度都不一样,在布局的 ...
随机推荐
- Cloudera Manager安装_搭建CDH集群
2017年2月22日, 星期三 Cloudera Manager安装_搭建CDH集群 cpu 内存16G 内存12G 内存8G 默认单核单线 CDH1_node9 Server || Agent ...
- 第六篇 项目疑问 ------- BaseService<T> where T : class, new() 含义
public abstract class BaseService<T> where T : class, new() { //当前仓储 //DbSession的存放 //为了职责单一的原 ...
- 关于Java空指针的控制(转)
1)在已经的String(字符串)调用 equal()和 equalsingnoreCase()而不是未知的对象 通常在已经的非空字符串在调用equals().因为equal()方法是对称的,调用a. ...
- 用VUEJS做一个猫眼电影web app
之前一直在学习原生js,可是发现原生js虽然很好,但是想实现一个稍微复杂一点的项目都很麻烦.直到遇见了vue.js,发现vue是真的很好用,而且很简洁,利用组件化开发能够快速做出项目,所以为了学习vu ...
- 【2017-03-10】Tsql语句基础、条件,高级查询
一.语句基础 1.创建数据库:create database 数据库名(不能汉字,不能数字.符号开头) 2.删除数据库:drop database 数据库名 3.选用数据库:use 数据库名 4.创建 ...
- I3D Next-Gen Game Development with Unity3D Vol I学习笔记(上)
这部教程主题是讲述如何在Unity中安放模型以及对场景进行优化(面对的是次世代平台).第二章看到一半,看不下,索性直接凭借Maya和Torque的经验自己操作. 看教程总结的原则如下(or tips) ...
- wemall app商城源码Android中ViewHolder详细解释
1.ViewHolder的解释: (1).只是一个静态类,不是Android的API方法. (2).它的作用就在于减少不必要的调用findViewById,然后把对底下的控件引用存在ViewHolde ...
- DOM的内部插入和外部插入
/*****************返回值都是最前面调用这个方法的元素 ***************** */ //这是外部插入 $("div").insertBefore($( ...
- HTML5学习笔记<一>: 认识H5
什么是 HTML5? HTML5 将成为 HTML.XHTML 以及 HTML DOM 的新标准. HTML 的上一个版本诞生于 1999 年.自从那以后,Web 世界已经经历了巨变. HTML5 仍 ...
- mybatis基础学习2---(resultType和resultMap的用法和区别)和setting的用法
1:resultType和resultMap两者只能有一个成立 2:resultMap可以解决复杂查询时的映射问题 3:使用 resultType使用 ------------------------ ...