Flex 布局 ------ 父项常见属性

简介: Flex 布局 ------ 父项常见属性

一、flex-direction 设置主轴的方向。

flex-direction: 设置主轴的方向。


默认主轴方向就是 x 轴 ( 默认 flex-direction: row),水平向右。

默认侧轴方向就是 y 轴,水平向下。

可以设置主轴方向为 y 轴 flex-direction: column

flex-direction 属性决定主轴的方向,元素跟着主轴排列。

flex-direction 属性值 和 说明 如下

row:默认值从左到右

row-reverse: 从右到左

column: 从上到下

column-reverse: 从下到上

05792ded70494277917dffd7755b5895.png

<!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>
        div{
            /* 给父级添加 flex 属性 */
            display: flex;
            width: 500px;
            height: 200px;
            background-color: pink;
            /* 默认的主轴是 x 轴 */
            /* 元素跟着主轴排列的 */
            flex-direction: row;   /*默认*/
            /* flex-direction: row-reverse; */
            /* flex-direction: column; */
            /* flex-direction: column-reverse; */
        }
        div span{
            width: 150px;
            height: 100px;
            color:white;
            background-color: purple;
        }
    </style>
</head>
<body>
    <div>
        <span>1</span>
        <span>2</span>
        <span>3</span>
    </div>
</body>
</html>

二、justify-content 设置主轴上的子元素排列方式。

justify-content: 设置主轴上的子元素排列方式。

  1. justify-content 属性定义了项目在主轴上的对齐方式。
  2. 注意:在使用这个属性之前一定要确定好主轴是哪一个。
  3. justify-content 属性值 和 说明 如下


flex-start:默认值 从头部开始,如果主轴是x轴,则从左到右。

flex-end: 从尾部开始排列

center:在主轴居中对齐(如果主轴是x轴则 水平居中)

space-around:平分剩余空间。

space-between:先两边贴边 再平分剩余空间(重要)

2503303d7c654084a4ce6f71cc79beec.png

99cdda6682644f5db0bc027a2f21e448.png

<!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>Document</title>
    <style>
        div {
            display: flex;
            width: 800px;
            height: 300px;
            background-color: pink;
            /* 默认的主轴是 x 轴 row */
            flex-direction: row;
            /* justify-content: 是设置主轴上子元素的排列方式 */
            justify-content: flex-start;
            justify-content: flex-end;
            /* 子元素居中对齐 */
            justify-content: center;
            /* 平分剩余空间 */
            justify-content: space-around;
            /* 先两边贴边,再分配剩余空间 */
            justify-content: space-between;
        }
        div span {
            width: 150px;
            height: 100px;
            background-color: purple;
        }
    </style>
</head>
<body>
    <div>
        <span>1</span>
        <span>2</span>
        <span>3</span>
    </div>
</body>
</html>

三、flex-wrap 设置子元素是否换行

flex-wrap: 设置子元素是否换行。


默认情况下,项目都排在一条线(又称 “轴线”)上。flex-wrap属性定义,flex布局中默认是不换行的。

flex 布局中,默认的子元素是不换行的,如果装不开会缩小子元素的宽度,放到父元素里面。

左边:flex-wrap: nowrap; 默认不换行。

右边:flex-wrap: wrap; 换行。

bb5673f333164fdfb32223b7e90d1c2d.png

flex-wrap 属性值 和 说明 如下

nowrap:默认值,不换行。

wrap:换行。

<!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>Document</title>
    <style>
        div { 
            display: flex;
            width: 600px;
            height: 400px;
            background-color: pink;
            /* flex 布局中,默认的子元素是不换行的,如果装不开会缩小子元素的宽度,放到父元素里面。 */
            flex-wrap: wrap;
        }
        div span {
            width: 150px;
            height: 100px;
            background-color: purple;
            color: #fff;
            margin: 10px;
        }
    </style>
</head>
<body>
    <div>
        <span>1</span>
        <span>2</span>
        <span>3</span>
        <span>4</span>
        <span>5</span>
        <span>6</span>
    </div>
</body>
</html>

四、align-items 设置侧轴上的子元素排列方式(单行)

align-items: 设置侧轴上的子元素排列方式(单行)

  1. 该属性是控制子项在侧轴(默认是 x 轴)上的排列方式,在子项为单项的时候使用。

主轴为 x 轴时

9f434679caf549fd83c63f97c7cae2b2.png

主轴为 y 轴时

44cd994ab8e34a2299c93db743c704ac.png

align-items 属性值 和 说明 如下

flex-start:默认值 从上到下

flex-end:从下到上

center:挤在一起(垂直居中)

stretch:拉伸

<!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>Document</title>
    <style>
        div {
            display: flex;
            width: 800px;
            height: 400px;
            background-color: pink;
            /* 默认的主轴是 x 轴 row */
            flex-direction: row;
            /* 设置主轴为 y 轴 column */
            /* flex-direction: column;  */
            justify-content: center;
            /* 需要一个侧轴居中 */
            align-items: center;
        }
        div span {
            width: 150px;
            height: 100px;
            background-color: purple;
            color: #fff;
            margin: 10px;
        }
    </style>
</head>
<body>
    <div>
        <span>1</span>
        <span>2</span>
        <span>3</span>
    </div>
</body>
</html>

五、align-content 设置侧轴上的子元素排列方式(多行)

  1. 设置子项在侧轴上的排列方式并且只能用于子项出现换行的情况(多行),在单行下是没有效果的。
  2. 88331df7470b4dd1ac3a313f38451585.png
  3. cfbb861305eb42cfaf4e20446c043a37.png
  4. align-content 属性值 和 说明 如下


flex-start:默认值 在侧轴的头部开始排列

flex-end:在侧轴的尾部开始排列

center:在侧轴中间显示

space-around:子项在侧轴平分剩余空间

space-between:子项在侧轴先分布在两头,再平分剩余空间

stretch:设置子项元素高度平分父元素高度拉伸

align-content 和 align-items 的区别


align-items 适用于单行情况下,只有上对齐、下对齐、居中和拉伸。

align-content 适用于换行(多行)的情况下(单行情况下失效),可以设置上对齐、下对齐、居中、拉伸以及平均分配剩余空间等属性值。

总结就是单行找 align-items ,多行找 align-content。

<!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>Document</title>
    <style>
        div {
            display: flex;
            width: 500px;
            height: 400px;
            background-color: pink;
            /* 换行 */
            flex-wrap: wrap;
            /* 因为有了换行,此时,我们侧轴上控制子元素的对齐方式用 align-content */
            /* align-content: flex-start; */
            /* align-content: flex-end; */
            /* align-content: center; */
            /* align-content: space-between; */
            align-content: space-around;
        }
        div span {
            width: 120px;
            height: 120px;
            background-color: purple;
            color: #fff;
            margin: 10px;
        }
    </style>
</head>
<body>
    <div>
        <span>1</span>
        <span>2</span>
        <span>3</span>
        <span>4</span>
        <span>5</span>
        <span>6</span>
    </div>
</body>
</html>

六、flex-flow 是 flex-direction 和 flex-wrap 属性的复合写法

flex-flow: column wrap; 等同于 flex-direction: column; flex-wrap: wrap;

e9d349c8f62d4e73a6f945f73e3f0768.png

两种方法同种效果

<!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>Document</title>
    <style>
        div {
            display: flex;
            width: 600px;
            height: 300px;
            background-color: pink;
            /* flex-direction: column;
            flex-wrap: wrap; */
            /* 把设置主轴方向和是否换行(换列)简写 */
            flex-flow: column wrap;
        }
        div span {
            width: 150px;
            height: 100px;
            background-color: purple;
            color: #fff;
        }
    </style>
</head>
<body>
    <div>
        <span>1</span>
        <span>2</span>
        <span>3</span>
        <span>4</span>
        <span>5</span>
        <span>6</span>
    </div>
</body>
</html>

总结:


flex-direction:设置主轴的方向

justify-content:设置主轴上的子元素排列方式

flex-wrap:设置子元素是否换行

align-content:设置侧轴上的子元素的排列方式(多行)

align-items:设置侧轴上的子元素排列方式(单行)

flex-flow:复合属性,相当于同时设置了 flex-direction 和 flex-wrap

不积跬步无以至千里 不积小流无以成江海


相关文章
|
2月前
|
开发者 容器
flex 布局属性在实际项目中的应用场景有哪些?
flex 布局属性在实际项目中的应用场景有哪些?
|
1月前
|
前端开发 UED 容器
使用 Flex 布局实现垂直居中效果
【10月更文挑战第7天】
112 57
|
22天前
|
前端开发 UED 容器
在 CSS 中使用 Flex 布局实现页面自适应时需要注意什么?
【10月更文挑战第22天】在使用 Flex 布局实现页面自适应时,需要对其基本原理和特性有深入的理解,同时结合具体的布局需求和场景,进行细致的调整和优化。通过合理的设置和注意事项的把握,才能实现理想的自适应效果,提升用户体验。还可以根据实际情况进行更深入的探索和实践,以不断提升 Flex 布局的应用能力。
|
9天前
|
容器
HTML中使用Flex布局实现双行夹批效果
在HTML中,还可以用table元素来实现双行夹批效果,但比flex布局代码更复杂,效果也不见得更理想。
|
11天前
|
开发者 UED 容器
鸿蒙next版开发:ArkTS组件通用属性(Flex布局)
在HarmonyOS next中,ArkTS的Flex布局是一种强大且灵活的布局方式,支持水平或垂直方向排列元素,并能动态调整大小和位置以适应不同屏幕。主要属性包括justifyContent、alignItems、direction和wrap,适用于导航栏、侧边栏和表单等多种场景。示例代码展示了如何使用这些属性创建美观的布局。
42 10
|
22天前
|
容器
在 Flex 布局中,如何设置元素在侧轴上的初始对齐方式?
【10月更文挑战第22天】同时,还可以进一步探索其他 Flex 布局相关的属性和技巧,以更好地掌握 Flex 布局的强大功能,创造出更具创意和适应性的页面布局。
25 2
|
1月前
|
前端开发 容器
flex布局
【10月更文挑战第7天】
28 1
|
1月前
多个p标签,并让div“flex”布局,且单行溢出隐藏
多个p标签,并让div“flex”布局,且单行溢出隐藏
28 0
|
1月前
|
容器
flex布局
flex布局
44 0
flex布局属性简介
flex布局属性简介