flex给我实现一个对角线布局

简介: flex在css布局中的是一个经常考察的知识点,虽然垂直居中问题已经问得快烂大街了,flex你虽然总是在用,但是总会有你不知道的盲点

01d6e67c859fe954d709d162a559cc90.jpg

flex在css布局中的是一个经常考察的知识点,虽然垂直居中问题已经问得快烂大街了,flex你虽然总是在用,但是总会有你不知道的盲点


本文是一篇关于flex布局相关的总结笔记,遇到比较刁钻的问题,就当个知识拓展吧

在阅读本文之前,主要从以下几个方向去探讨flex


  • flex布局又称为弹性布局,有何特征
  • 关于flex的一些属性值
  • flex如何实现垂直居中,如何实现一个对角排列布局


flex特征


当我们对一个元素设置flex后,其子元素所有的floatcleanvertical-align属性都会失效,并且默认水平排列,并且宽度由自身元素内容决定。


影响主轴与交叉轴的属性


  • flex-direction


主要影响水平轴排列还是交叉轴排列

.wrap-box {
  display: flex;
  // flex-direction: row; 默认从左往右
  flex-direction: row-revers; 顺序从右往左 
  flex-direction: column; 从上往下 
  flex-direction: column-reverse; 从下往上 
}

365fbe046a0091ca7eaf6bd7263c8740.png

  • flex-wrap 主要影响水平轴元素是否换行,默认不换行flex-wrap:nowrap

.wrap-box {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap // 不换行
  // flex-wrap: wrap // 换行
  // flex-wrap: wrap-reverse 换行从下往上依次排列
}
  • flex-flow


这个属性主要是flex-directionflex-wrap的结合体

.wrap-box {
  display: flex;
  flex-flow: row nowrap // 默认
}
  • justify-content


主要影响水平主轴的排列顺序

.wrap-box {
  display: flex;
  justify-content: flex-start // 左对齐排列
  // justify-content: center // 居中排列
  // justify-content: space-between // 两端对齐排列
  // justify-content: space-around // 间隔相等排列
  // justify-content: flex-end // 居右排列
}
  • align-items


主要影响交叉轴垂直方向的排列

.wrap-box {
  display: flex;
  align-items: flex-start; // 垂直方向从上往下排列
  // align-items: center 垂直方向居中排列
  // align-items: flex-end 垂直方向从下往上排列
  // align-items: stretch 会将子元素高度拉伸父元素一致(子元素未设置高度)
}

f20a64b8e9f9d1c720cc9bf25a4bbebe.png


关于item项目设置的属性


  • order


决定子项目的顺序,order越小,越是排列在最前面


假设现在有个需求,css实现简单的跑马灯

<div class="wrap-box">
    <div class="item-1">1</div>
    <div class="item-2">2</div>
    <div class="item-3">3</div>
 </div>

对应的css

@keyframes ani-1 {
        0% {
          order: 0;
        }
        50% {
          order: 1;
        }
        100% {
          order: 2;
        }
      }
      @keyframes ani-2 {
        0% {
          order: 1;
        }
        50% {
          order: 0;
        }
        100% {
          order: 1;
        }
      }
      @keyframes ani-3 {
        0% {
          order: 2;
        }
        50% {
          order: 2;
        }
        100% {
          order: 0;
        }
      }
  .wrap-box {
        width: 500px;
        height: 500px;
        overflow: hidden;
        display: flex;
        background-color: green;
        align-items: stretch;
      }
      .wrap-box .item-1,
      .wrap-box .item-2,
      .wrap-box .item-3 {
        width: 100px;
        height: 100px;
        background-color: red;
      }
      .wrap-box .item-1 {
        animation: ani-1 5s infinite;
        transition: order 1s ease;
      }
      .wrap-box .item-2 {
        animation: ani-2 5s infinite;
        transition: order 1s ease;
      }
      .wrap-box .item-3 {
        animation: ani-3 5s infinite;
        transition: order 1s ease;
      }

我们利用css3的动画帧,改变order的顺序,因此一个简易的css跑马灯就实现了,而且并没有改变dom的结构和顺序

52cd99f61a304c6a172279f8d956c6b3.jpg

  • flex-basis


设置当前的item的固定宽度

.wrap-box .item-3{
  flex-basis: 200px;
}

b862b75626b20e5e07ecaa42cb4c3078.png

  • flex-grow


该属性是决定当前item的放大比例,默认是0

1242fc2e20ab6c0439c265b6580639cc.png

比如三个div,左右固定,中间内容自动撑开

b19c054035fccab185146a6386a9e93e.png


  • flex-shrink


当前item的缩小比例,默认的是0


  • align-self


能控制单个item的排列,这个属性通常不是很常用,面试曾被这个css的属性布局问题给跪了


面试题大概是这样的,3个子div实现一个对角线布局,用flex布局,如果没想到这个align-self大概是实现不了

.wrap-box {
    width: 500px;
    height: 500px;
    overflow: hidden;
    background-color: green;
    display: flex;
    justify-content: space-between;
}
 .wrap-box .item-1,
  .wrap-box .item-2,
  .wrap-box .item-3 {
    width: 100px;
    height: 100px;
    background-color: red;
}
.wrap-box .item-2 {
  align-self: center; // 垂直居中
}
.wrap-box .item-3 {
  align-self: flex-end; // 靠右
}

设置对应的item大概就是下面这样了

5d9d071738ddb88501e8511bb5103d23.png

479cbafaa36d9696eda7f74121798ed8.png


关于flex:1的详解


通常我们设置flex:1,其实本质上是替代了以下几个参数

.item3 {
  flex-grow:1;
  flex-shrink:1;
  flex-basis: 0%;
}


元素垂直居中


以下是一个基本的页面结构

<div class="wrap">
    <div class="inner-box"></div>
</div>

.wrap {
        width: 100px;
        height: 100px;
        display: flex;
        justify-content: center;
        align-items: center;
        background-color: red;
}
.wrap .inner-box {
  width: 50px;
  height: 50px;
  background: green;
}


572a6cdde51d0128337073956c596613.png


总结


  • 了解flex基本特征,影响水平轴与交叉轴的的属性主要受flex-direction这个属性的,默认水平row排列
  • 当一个父级元素设置flex后,子级的浮动clear,vertain-align属性都会失效,默认所有子级元素水平排列
  • flex的一些特性,比如放大flex-glow、缩小flex-shrink,还有影响水平轴排列just-content,以及交叉轴排列align-items属性的设置
  • align-self 这个属性可以单独控制当前元素的位置
  • flex实现一个垂直居中
  • 本文code example[1]
相关文章
|
3月前
|
开发者 容器
flex 布局属性在实际项目中的应用场景有哪些?
flex 布局属性在实际项目中的应用场景有哪些?
|
26天前
|
容器
Bootstrap5 Flex(弹性)布局4
排序:.order 类可设置弹性子元素的排序,范围从 .order-1 至 .order-12,数字越小优先级越高。外边距:.ms-auto 和 .me-auto 分别用于设置子元素的右侧和左侧外边距为 auto。包裹:.flex-nowrap(默认)、.flex-wrap 和 .flex-wrap-reverse 用于控制弹性容器中的子元素是否换行及换行方向。
|
2月前
|
前端开发 UED 容器
使用 Flex 布局实现垂直居中效果
【10月更文挑战第7天】
288 57
|
25天前
|
容器
Bootstrap5 Flex(弹性)布局6
使用 `.align-self-*` 类可控制指定子元素的对齐方式,包括 `.align-self-start`, `.align-self-end`, `.align-self-center`, `.align-self-baseline`, 和 `.align-self-stretch`。示例代码展示了如何在一个弹性布局中应用这些类,以实现不同设备上的响应式设计。
|
25天前
Bootstrap5 Flex(弹性)布局5
使用 .align-content-* 控制多行子元素在垂直方向上的堆叠方式,如 .align-content-start、.align-content-center 等。对于单行子元素,使用 .align-items-* 控制对齐,例如 .align-items-start、.align-items-center 等。示例代码展示了不同对齐效果的应用。
|
26天前
Bootstrap5 Flex(弹性)布局2
介绍Flex布局的水平和垂直方向控制。`.flex-row`使子元素水平排列,默认左对齐;`.flex-row-reverse`则右对齐。`.flex-column`让子元素垂直排列;`.flex-column-reverse`则反向排列。示例展示了不同类的效果,通过改变类名实现布局调整。
|
26天前
Bootstrap5 Flex(弹性)布局3
`.justify-content-*` 类用于调整弹性子元素的对齐方式,支持 start、end、center、between、around 等值。`.flex-fill` 类使所有子元素等宽,而 `.flex-grow-1` 则让指定子元素占据剩余空间。这些类在布局设计中非常实用。
|
1月前
|
前端开发 UED 容器
在 CSS 中使用 Flex 布局实现页面自适应时需要注意什么?
【10月更文挑战第22天】在使用 Flex 布局实现页面自适应时,需要对其基本原理和特性有深入的理解,同时结合具体的布局需求和场景,进行细致的调整和优化。通过合理的设置和注意事项的把握,才能实现理想的自适应效果,提升用户体验。还可以根据实际情况进行更深入的探索和实践,以不断提升 Flex 布局的应用能力。
|
1月前
|
容器
HTML中使用Flex布局实现双行夹批效果
在HTML中,还可以用table元素来实现双行夹批效果,但比flex布局代码更复杂,效果也不见得更理想。
43 10
|
1月前
|
开发者 UED 容器
鸿蒙next版开发:ArkTS组件通用属性(Flex布局)
在HarmonyOS next中,ArkTS的Flex布局是一种强大且灵活的布局方式,支持水平或垂直方向排列元素,并能动态调整大小和位置以适应不同屏幕。主要属性包括justifyContent、alignItems、direction和wrap,适用于导航栏、侧边栏和表单等多种场景。示例代码展示了如何使用这些属性创建美观的布局。
80 10

热门文章

最新文章