flex

PheonixHkbxoic PheonixHkbxoic     2022-08-12     544

关键词:

Flex 布局教程:实例篇

学习阮大大的Flex布局,想看原文请移步: 阮一峰

介绍了Flex布局的语法,今天介绍常见布局的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... 查看详情