深入探索Flex布局:从基础到实战,附带抖音解决方案案例分析

简介

在阅读本文之前,请确保你已经掌握CSS基本语法、常用属性以及CSS选择器。

盒模型是CSS布局的重要概念,它可以调整不同元素之间和元素内部之间的间距。

Flex布局是目前企业开发中常用的弹性灵活布局方案,常用于响应式和移动端开发。

本文总结了盒模型和Flex布局常用属性,可作为文档在使用时进行查阅。

盒子模型

概念

盒子模型是CSS的重要概念,用于布局组件,设置组件与组件之间和组件内部的间距。

盒子模型组成部分:

  • 内容区域:width & height
  • 内边距:padding
  • 边框线:border
  • 外边距:margin

image-20240212173453698

我们通常将div作为盒子,padding即边框和内容之间的间距,border即盒子边框线,margin则是盒子与盒子之间的间距。

默认情况,指定盒模型的width和height是内容区域的大小。我们可以通过box-sizing: border-box;属性设置盒子大小为包含padding和margin的大小。

本文重点讲解Flex布局,关于盒模型的具体细节可以参考w3school。如果感兴趣可以了解下margin的合并和塌陷问题。

版心居中

我们通常使用auto来使版心居中:

div {
   margin: 0 auto; 
}

Flex布局

Flex布局即CSS弹性盒子模型(Flexible Box 或 Flexbox),实现网页在不同分辨率设备上自适应而生的一种布局方式。

flex布局常用属性:

描述属性
创建flex容器display: flex
主轴对齐方式justify-content
侧轴对齐方式align-items
某个弹性盒子侧轴对齐方式align-self
修改主轴方向flex-direction
弹性伸缩比flex
弹性盒子换行flex-wrap
行对齐方式align-content

组成

设置方式:给父元素设置display: flex;子元素可以自动挤压和拉伸。

组成部分:

  • 弹性容器
  • 弹性盒子
  • 主轴:默认在水平方向。
  • 侧轴/交叉轴:默认在垂直方向。
image-20240211213127279

例:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>flex布局-组成</title>
  <style>
    /* 弹性容器 */
    .box {
      height: 300px;
      border: 1px solid #000;
    }

    /* 弹性盒子:沿着主轴方向排列 */
    .box div {
      width: 200px;
      height: 100px;
      background-color: pink;
    }
  </style>
</head>
<body>
  <div class="box">
    <div>1</div>
    <div>2</div>
    <div>3</div>
  </div>
</body>
</html>

div为块级元素,因此效果如下图所示:

image-20240211213701613

我们设置父级的display为flex:

.box {
      display: flex;
      height: 300px;
      border: 1px solid #000;
    }

div成了弹性盒子,自动排列成了一行:

image-20240211213520881

如果我们多放几个div:

<body>
  <div class="box">
    <div>1</div>
    <div>2</div>
    <div>3</div>
    <div>1</div>
    <div>2</div>
    <div>3</div>
    <div>1</div>
    <div>2</div>
    <div>3</div>
  </div>
</body>
</html>

弹性盒子的宽度会自动挤压,排列在一行:

image-20240211213632645

主轴对齐方式

盒子之间的间距往往通过margin设置,但在flex布局中的弹性盒子的间距可以使用justify-content属性设置主轴对齐方式来实现。

常见的justify-content属性值如下:

属性值效果
flex-start默认值,弹性盒子从起点开始依次排列
flex-end弹性盒子从终点开始依次排列
center弹性盒子沿主轴居中排列
space-between弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子之间
space-around弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子两侧
space-evenly弹性盒子沿主轴均匀排列,弹性盒子与容器之间间距相等

flex-start:

image-20240212163911515

flex-end:

image-20240212163858574

center:

image-20240212163843159

space-between(父级剩余宽度平均分配在弹性盒子之间):

image-20240212163948236

space-around(父级剩余宽度平均分配在弹性盒子两侧,弹性盒子之间的距离是两侧的2倍):

image-20240212164007946

space-evenly(弹性盒子之间、弹性盒子与弹性容器之间间距相等):

image-20240212164026992

侧轴对齐方式

通过align-items可以控制弹性盒子在侧轴的对齐方式,也可以通过align-self属性单独控制某个弹性盒子在侧轴对齐方式。

常用属性值如下:

属性值效果
stretch弹性盒子沿侧轴线拉伸至铺满容器
center弹性盒子沿侧轴居中
flex-start弹性盒子从侧轴起点依次排列
flex-end弹性盒子从侧轴终点依次排列

stretch(弹性盒子在侧轴没有尺寸才能拉伸):

image-20240212164835368

center:

image-20240212164857758

flex-start:

image-20240212164935254

flex-end:

image-20240212164954979

通过结构伪类选择器,单独设置第二个div为center:

.box div:nth-child(2) {
	align-self: center;
}
image-20240212165133259

修改主轴方向

flex-direction可以改变主轴方向,常用属性值:

属性值效果
row水平方向,从左向右(默认)
column垂直方向,从上向下
row-reverse水平方向,从右向左
column-reverse垂直方向,从下向上

row和column效果依次如下:

image-20240212170243572

弹性伸缩比

弹性伸缩比可以控制弹性盒子的主轴方向的尺寸,通过flex属性进行控制,属性值为整数表示占用父级剩余尺寸的份数。

例如,对下面四个弹性容器进行排版,每个弹性容器的份数都设置为1,则4个弹性容器就可以均分父级尺寸。

image-20240212170800025

设置div1固定宽度,div2的flex: 1, div3的flex:2。效果如下图所示:

image-20240212170954572

弹性盒子换行

通过flex-wrap属性可以设置换行,属性值分为wrap(换行)和nowrap(不换行,默认)。

flex-wrap: wrap效果如下图所示:

image-20240212171809509

行对齐方式

上面我们已经实现了弹性盒子自动换行,现在可以通过align-content设置行与行的对齐方式。

align-content的常见属性值(和主轴对齐方式justify-content一致):

属性值效果
flex-start默认值,弹性盒子从起点开始依次排列
flex-end弹性盒子从终点开始依次排列
center弹性盒子沿主轴居中排列
space-between弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子之间
space-around弹性盒子沿主轴均匀排列,空白间距均分在弹性盒子两侧
space-evenly弹性盒子沿主轴均匀排列,弹性盒子与主轴之间间距相等

案例-抖音解决方案

效果图

image-20240212172500006

案例分析

  1. 这里使用的是无序列表ul,因此需要创建div > ul > li *4。
  2. 对列表项ul进行布局,可以使用float或flex,推荐使用flex。
  3. 需要换行,因此使用flex-wrap: wrap。
  4. 分析单独一行,发现间距在两个div之间,因此主轴对齐方式可以使用space-between。
  5. 行与行间距也在div之间,因此行对齐方式采用space-between。

参考代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>抖音解决方案</title>
  <style>
    * {
      /* 清除默认样式 */
      margin: 0;
      padding: 0;
      /* 使盒模型尺寸包含border和padding */
      box-sizing: border-box;
    }

    li {
      list-style: none;
    }

    .box {
      margin: 50px auto;
      width: 1200px;
      height: 418px;
      border: 1px solid #ddd;
      border-radius: 10px;
    }

    .box ul {
      display: flex;
      /* 弹性盒子换行 */
      flex-wrap: wrap;
      /* 调整主轴对齐方式 */
      justify-content: space-between;

      /* 调整 行对齐方式 */
      align-content: space-between;

      padding: 90px 40px 90px 60px;
      height: 418px;
    }

    .box li {
      display: flex;
      width: 500px;
      height: 88px;
      /* background-color: pink; */
    }

    .box .pic {
      margin-right: 15px;
    }

    .box .text h4 {
      line-height: 40px;
      font-size: 20px;
      font-weight: 400;
      color: #333;
    }

    .box .text p {
      font-size: 14px;
      color: #666;
    }
  </style>
</head>
<body>
  <div class="box">
    <ul>
      <li>
        <div class="pic">
          <img src="./images/1.svg" alt="">
        </div>
        <div class="text">
          <h4>一键发布多端</h4>
          <p>发布视频到抖音短视频、西瓜视频及今日头条</p>
        </div>
      </li>
      <li>
        <div class="pic">
          <img src="./images/2.svg" alt="">
        </div>
        <div class="text">
          <h4>管理视频内容</h4>
          <p>支持修改已发布稿件状态和实时查询视频审核状态</p>
        </div>
      </li>
      <li>
        <div class="pic">
          <img src="./images/3.svg" alt="">
        </div>
        <div class="text">
          <h4>发布携带组件</h4>
          <p>支持分享内容携带小程序、地理位置信息等组件,扩展内容及突出地域性</p>
        </div>
      </li>
      <li>
        <div class="pic">
          <img src="./images/4.svg" alt="">
        </div>
        <div class="text">
          <h4>数据评估分析</h4>
          <p>获取视频在对应产品内的数据表现、获取抖音热点,及时进行表现评估</p>
        </div>
      </li>
    </ul>
  </div>
</body>
</html>

领取完整源码

关注微信公众号:Real返璞归真,后台回复【抖音解决方案】获取完整源代码+素材下载地址。

本公众号不定期更新前后端开发、算法/数据结构、网络安全相关知识,欢迎关注,为我提供更多创作动力。

wx_qrcode
  • 20
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值