11.5 flex容器设置

flex容器设置包括:flex-direction、flex-wrap、flex-flow、justify-content、align-items、align-content、gap。


11.5.1 方向flex-direction

包括4个值:水平row、水平反转row-reverse、垂直column、垂直反转column-reverse。

img

img

开发者工具示意图如下,可直接进行调试设置。

img

flex-direction默认值row,表示子元素显示在一行;值column表示显示在一列。

        .parent{
            display: flex;
            flex-direction: column;
            border: 1px solid #666;
        }

运行效果

img


11.5.2 垂直排列应用于响应式布局

垂直方向排列主要用于响应式布局。当窗口较宽时按列排,当调整窗口变窄或小尺寸设备(例如手机)窗口本身就窄,则按行排。

示例代码

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>小步教程</title>

    <style>
        *{
            box-sizing: border-box;
        }
        .parent{
            display: flex;            
            border: 1px solid #666;
        }

        @media screen and (max-width : 520px) {
            .parent{
                flex-direction: column;
            }
        }

        [class^="col"]{
            width: 150px;
        }

        .col1{
            background-color: #0aaa76;
        }

        .col2{
            background-color: #4aa6fc;
        }

        .col3{
            background-color: #ed7d31;
            height: 80px;
        }
    </style>
</head>
<body>
    <div class="parent">
        <div class="col1">
            <div>第1列</div>
            <div>小步教程</div>
        </div>
        <div class="col2">
            <div>第2列</div>
            <div>xiaobuteach.com</div>
        </div>
        <div class="col3">
            <div>第3列</div>
            <div>每列可继续加入复杂布局</div>
        </div>
    </div>
</body>
</html>

@media用于响应式布局,也称媒体查询,用于根据窗口尺寸设置样式。

运行效果。当窗口大小>520px时,按列显示。

img

调整窗口宽度小于或等于520px时。

img


11.5.3 主轴与从轴

(1)不使用专用术语的描述

flex-direction: row表示首先沿x轴排列,当flex-wrap: wrap允许换行,换行动作即沿y轴自动排列,换行后各元素继续x轴排列。

img

flex-direction: column表示首先沿y轴排列,且flex-wrap: wrap允许“自动换行”,“自动换行”即沿x轴排列,“自动换行”后各元素继续y轴排列。

img

(2)使用专用术语的统一描述

元素首先沿主轴排列,主轴宽度不够,沿从轴进行“换行”,然后继续沿主轴排列。首先沿哪根轴排列,即主轴main axis,“自动换行”动作沿哪根轴排列,即从轴(交叉轴)cross axis。

排列示意图统一如下。

img

本教程后续讲解不使用主轴/从轴这套术语,不易理解。

flex容器设置更多内容见第7节。