关键词:
Flex 布局教程:实例篇
你会看到,不管是什么布局,Flex往往都可以几行命令搞定。
我只列出代码,详细的语法解释请查阅《Flex布局教程:语法篇》。我的主要参考资料是Landon Schropp的文章和Solved by Flexbox。
一、骰子的布局
骰子的一面,最多可以放置9个点。
下面,就来看看Flex如何实现,从1个点到9个点的布局。你可以到codepen查看Demo。
如果不加说明,本节的HTML模板一律如下。
<div class="box"> <span class="item"></span> </div>
上面代码中,div元素(代表骰子的一个面)是Flex容器,span元素(代表一个点)是Flex项目。如果有多个项目,就要添加多个span元素,以此类推。
1.1 单项目
首先,只有左上角1个点的情况。Flex布局默认就是首行左对齐,所以一行代码就够了。
.box { display: flex; }
设置项目的对齐方式,就能实现居中对齐和右对齐。
.box { display: flex; justify-content: center; }
.box { display: flex; justify-content: flex-end; }
设置交叉轴对齐方式,可以垂直移动主轴。
.box { display: flex; align-items: center; }
.box { display: flex; justify-content: center; align-items: center; }
.box { display: flex; justify-content: center; align-items: flex-end; }
.box { display: flex; justify-content: flex-end; align-items: flex-end; }
1.2 双项目
.box { display: flex; justify-content: space-between; }
.box { display: flex; flex-direction: column; justify-content: space-between; }
.box { display: flex; flex-direction: column; justify-content: space-between; align-items: center; }
.box { display: flex; flex-direction: column; justify-content: space-between; align-items: flex-end; }
.box { display: flex; } .item:nth-child(2) { align-self: center; }
.box { display: flex; justify-content: space-between; } .item:nth-child(2) { align-self: flex-end; }
1.3 三项目
.box { display: flex; } .item:nth-child(2) { align-self: center; } .item:nth-child(3) { align-self: flex-end; }
1.4 四项目
.box { display: flex; flex-wrap: wrap; justify-content: flex-end; align-content: space-between; }
HTML代码如下。
<div class="box"> <div class="column"> <span class="item"></span> <span class="item"></span> </div> <div class="column"> <span class="item"></span> <span class="item"></span> </div> </div>
CSS代码如下。
.box { display: flex; flex-wrap: wrap; align-content: space-between; } .column { flex-basis: 100%; display: flex; justify-content: space-between; }
1.5 六项目
.box { display: flex; flex-wrap: wrap; align-content: space-between; }
.box { display: flex; flex-direction: column; flex-wrap: wrap; align-content: space-between; }
HTML代码如下。
<div class="box"> <div class="row"> <span class="item"></span> <span class="item"></span> <span class="item"></span> </div> <div class="row"> <span class="item"></span> </div> <div class="row"> <span class="item"></span> <span class="item"></span> </div> </div>
CSS代码如下。
.box { display: flex; flex-wrap: wrap; } .row{ flex-basis: 100%; display:flex; } .row:nth-child(2){ justify-content: center; } .row:nth-child(3){ justify-content: space-between; }
1.6 九项目
.box { display: flex; flex-wrap: wrap; }
二、网格布局
2.1 基本网格布局
最简单的网格布局,就是平均分布。在容器里面平均分配空间,跟上面的骰子布局很像,但是需要设置项目的自动缩放。
HTML代码如下。
<div class="Grid"> <div class="Grid-cell">...</div> <div class="Grid-cell">...</div> <div class="Grid-cell">...</div> </div>
CSS代码如下。
.Grid { display: flex; } .Grid-cell { flex: 1; }
2.2 百分比布局
某个网格的宽度为固定的百分比,其余网格平均分配剩余的空间。
HTML代码如下。
<div class="Grid"> <div class="Grid-cell u-1of4">...</div> <div class="Grid-cell">...</div> <div class="Grid-cell u-1of3">...</div> </div>
.Grid { display: flex; } .Grid-cell { flex: 1; } .Grid-cell.u-full { flex: 0 0 100%; } .Grid-cell.u-1of2 { flex: 0 0 50%; } .Grid-cell.u-1of3 { flex: 0 0 33.3333%; } .Grid-cell.u-1of4 { flex: 0 0 25%; }
三、圣杯布局
圣杯布局(Holy Grail Layout)指的是一种最常见的网站布局。页面从上到下,分成三个部分:头部(header),躯干(body),尾部(footer)。其中躯干又水平分成三栏,从左到右为:导航、主栏、副栏。
HTML代码如下。
<body class="HolyGrail"> <header>...</header> <div class="HolyGrail-body"> <main class="HolyGrail-content">...</main> <nav class="HolyGrail-nav">...</nav> <aside class="HolyGrail-ads">...</aside> </div> <footer>...</footer> </body>
CSS代码如下。
.HolyGrail { display: flex; min-height: 100vh; flex-direction: column; } header, footer { flex: 1; } .HolyGrail-body { display: flex; flex: 1; } .HolyGrail-content { flex: 1; } .HolyGrail-nav, .HolyGrail-ads { /* 两个边栏的宽度设为12em */ flex: 0 0 12em; } .HolyGrail-nav { /* 导航放到最左边 */ order: -1; }
如果是小屏幕,躯干的三栏自动变为垂直叠加。
@media (max-width: 768px) { .HolyGrail-body { flex-direction: column; flex: 1; } .HolyGrail-nav, .HolyGrail-ads, .HolyGrail-content { flex: auto; } }
四、输入框的布局
我们常常需要在输入框的前方添加提示,后方添加按钮。
HTML代码如下。
<div class="InputAddOn"> <span class="InputAddOn-item">...</span> <input class="InputAddOn-field"> <button class="InputAddOn-item">...</button> </div>
CSS代码如下。
.InputAddOn { display: flex; } .InputAddOn-field { flex: 1; }
五、悬挂式布局
有时,主栏的左侧或右侧,需要添加一个图片栏。
HTML代码如下。
<div class="Media"> <img class="Media-figure" src="" alt=""> <p class="Media-body">...</p> </div>
CSS代码如下。
.Media { display: flex; align-items: flex-start; } .Media-figure { margin-right: 1em; } .Media-body { flex: 1; }
六、固定的底栏
有时,页面内容太少,无法占满一屏的高度,底栏就会抬高到页面的中间。这时可以采用Flex布局,让底栏总是出现在页面的底部。
HTML代码如下。
<body class="Site"> <header>...</header> <main class="Site-content">...</main> <footer>...</footer> </body>
CSS代码如下。
.Site { display: flex; min-height: 100vh; flex-direction: column; } .Site-content { flex: 1; }
七,流式布局
每行的项目数固定,会自动分行。
CSS的写法。
.parent { width: 200px; height: 150px; background-color: black; display: flex; flex-flow: row wrap; align-content: flex-start; } .child { box-sizing: border-box; background-color: white; flex: 0 0 25%; height: 50px; border: 1px solid red; }
(完)
flex:1到底是啥
参考技术A先说结论flex:1即为flex-grow:1,经常用作自适应布局,将父容器的display:flex,侧边栏大小固定后,将内容区flex:1,内容区则会自动放大占满剩余空间。flex属性是flex-grow,flex-shrink,flex-basis三个属性的缩写推荐使用此简... 查看详情
flex布局display:flex与inline-flex区别
1.Flex布局display:flex.bigboxwidth:500px;height:400px;background:#ff0000;display:flex;.smallboxwidth:100px;height:100px;background:# 查看详情
flex布局
flexiblebox弹性布局1.开始flex布局所有元素都支持flex布局.box{display:flex;}行内元素flex布局.box{display:inline-flex;}webkit内核浏览器.box{display:-webkit-flex;/*Safari*/display:flex;}常规布局方法使用的float,clear,vertical-align属性在flex中将失效 查看详情
common.css(代码片段)
通用样式remrem.flex-row-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;.flex-column-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;.flex-row,.flex-columndisplay:-webkit-flex;display:-moz-flex;display:-ms-flex;display:-o-flex;display:flex;-webkit... 查看详情
flex布局
一、Flex布局是什么?Flex是FlexibleBox的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。任何一个容器都可以指定为Flex布局。块级元素display:flex行内元素display:inline-flex注意 1>.Webkit内核的浏览器,必须加上-webkit前缀... 查看详情
flex布局
flex布局.box{display:flex; display:-webkit-flex;/*Safari*/} .item1{flex:0080px; width:80px}.item2{flex:1} 查看详情
flex:1和flex:auto详解(代码片段)
flex:1和flex:auto详解首先明确一点是,flex是flex-grow、flex-shrink、flex-basis的缩写。flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项... 查看详情
flex布局基础1
一、Flex布局是什么?Flex即:"弹性布局"任何一个容器都可以指定为Flex布局 .box{ display:flex; }行内元素也可以使用Flex布局 .box{ display:inline-flex; }webkit内核的浏览器,必须加上-webkit前缀 .box{ ... 查看详情
在 flex 速记中理解 flex-basis
】在flex速记中理解flex-basis【英文标题】:Understandingflex-basisinflexshorthand【发布时间】:2015-03-2311:43:11【问题描述】:我理解flex-grow:它允许flex项根据相对于同一行/列上其他flex项的比率增长。我了解flex-shrink:它允许flex项根据... 查看详情
flex布局
flex是flex-grow,flex-shrink和flex-basis三个属性的缩写。第二个和第三个参数(flex-shrink和flex-basis)是可选值。其默认值是01auto。flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。flex-shrink属性定义了项目的缩... 查看详情
img 设置 flex-grow 来填充 flex 容器的剩余空间,它会导致 flex 内部溢出 flex 容器 [重复]
】img设置flex-grow来填充flex容器的剩余空间,它会导致flex内部溢出flex容器[重复]【英文标题】:imgsetflex-growtofillflexcontainerrestspace,itcauseflexinneroverflowflexcontainer[duplicate]【发布时间】:2021-12-0704:45:42【问题描述】:以下是我的代码... 查看详情
flex: 1 是啥意思?
】flex:1是啥意思?【英文标题】:Whatdoesflex:1mean?flex:1是什么意思?【发布时间】:2016-09-2001:17:32【问题描述】:众所周知,flex属性是flex-grow、flex-shrink和flex-basis属性的简写。它的默认值为01auto,意思是flex-grow:0;flex-shrink:1;flex-bas... 查看详情
flex布局
Flex布局flex布局是FlexibleBox的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。任何一个容器都可以指定为Flex布局,包括行内元素,例如:.box{display:inline-flex;}Webkit内核的浏览器,必须加上-webkit前缀。.box{display:-webkit-fl... 查看详情
flex布局
一、Flex布局是什么?Flex是FlexibleBox的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性。任何一个容器都可以指定为Flex布局。.box{display:flex;}行内元素也可以使用Flex布局。.box{display:inline-flex;}Webkit内核的浏览器,必须... 查看详情
flex弹性布局属性详解!
flex容器属性详解:flex-direction:决定元素的排列方向;flex-wrap决定原色如何换行(排列不下时);flex-flow是:flex-direction和flex-wrap的简写;justify-content元素在主轴上的对齐方式;align-items元素在交叉轴的对齐方式;flex元素属性... 查看详情
flex基础语法
任何一个容器都可以指定为Flex布局。.box{display:flex;}行内元素也可以使用Flex布局。.box{display:inline-flex;}Webkit内核的浏览器,必须加上-webkit前缀。.box{display:-webkit-flex;/*Safari*/display:flex;}注意,设为Flex布局以后,子元素的float、clear... 查看详情
flex布局
1、基本概念1)Flex布局元素称为Flex容器,子元素称为Flex项目;2)容器存在两根轴:主轴mainaxis(默认是水平方向)和交叉轴crossaxis(默认是垂直方向);3)任何一个容器都可以指定为flex布局:块元素:display:flex;行内元素:display:... 查看详情
flex属性的取值
首先明确一点是,flex是flex-grow、flex-shrink、flex-basis的缩写。故其取值可以考虑以下情况:flex的默认值是以上三个属性值的组合。假设以上三个属性同样取默认值,则flex的默认值应当是01auto。同理,如下是等同的: .itemflex:23... 查看详情