CSS 弹性盒布局(flex)

  • IE浏览器正式停用了, 公司对低版本浏览器的要求也不严格了
  • 以前为了有更好的兼容性, 一直在使用老的语法, 对新语法掌握不足
  • 在以前的工作中弹性盒布局用的比较少, 今天就来学习一下使用方法

Flex 布局是什么

  • 我们经常会提到盒模型, 其实 CSS 的布局方式和盒模型是分不开的
  • 我们通常会通过 display 控制盒子的类型, 设置为弹性布局也是一样的, 即: display: flex; or display: inline-flex;
  • 设为 Flex 布局以后,子元素的floatclearvertical-align属性将失效。

基本概念

  • 容器默认存在两根轴:水平的主轴 (main axis)和垂直的交叉轴(cross axis)。
  • 主轴的开始位置(与边框的交叉点)叫做main start,结束位置叫做main end
  • 交叉轴的开始位置叫做cross start,结束位置叫做cross end
  • 项目默认沿主轴排列。单个项目占据的主轴空间叫做main size,占据的交叉轴空间叫做cross size

容器的属性

  • flex-direction (设置主轴)
  • flex-wrap (换行方式)
  • flex-flow (flex-directionflex-wrap 的简写)
  • justify-content (主轴对齐方式)
  • align-items (交叉轴对齐方式)
  • align-content (多个主轴时, 在交叉轴方向的对齐方式)
  • 以上6个属性是容器自身的属性。
  • 在谷歌浏览器中会有上图的面板, 即便没有用过也可以根据图形的示例设置(ps: 可能是因为这个导致我现在还不知道 flex 都有什么用法)
  • 虽然工具很好用, 但是我们也应该了解一下他的具体用法, 我们接着往下看

flex-direction 主轴的方向(排列方向)

css 复制代码
flex-direction: row | row-reverse | column | column-reverse;
  • row(默认值):主轴为水平方向,起点在左端。
  • row-reverse:主轴为水平方向,起点在右端。
  • column:主轴为垂直方向,起点在上沿。
  • column-reverse:主轴为垂直方向,起点在下沿。

flex-wrap 排不下如何换行

css 复制代码
flex-wrap: nowrap | wrap | wrap-reverse;
  • nowrap:不换行, 位置不够时挤压子容器
  • wrap:换行
  • wrap-reverse:换行, 第一行在最下面。

flex-flow (flex-directionflex-wrap 的简写)

css 复制代码
/* flex-flow: <flex-direction> || <flex-wrap>; */
flex-flow: column-reverse wrap;

justify-content 设置主轴对齐方式

css 复制代码
justify-content: flex-start | flex-end | center | space-between | space-around;
  • flex-start(默认值):左对齐
  • flex-end:右对齐
  • center: 居中
  • space-between:两端对齐,项目之间的间隔都相等。
  • space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。

align-items 设置交叉轴对齐方式(和主轴类似)

css 复制代码
align-items: flex-start | flex-end | center | baseline | stretch;
  • flex-start:交叉轴的起点对齐。
  • flex-end:交叉轴的终点对齐。
  • center:交叉轴的中点对齐。
  • baseline: 项目的第一行文字的基线对齐。
  • stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。

align-content 多个主轴时在交叉轴上的对齐方式

  • 多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。
css 复制代码
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
  • flex-start:与交叉轴的起点对齐。
  • flex-end:与交叉轴的终点对齐。
  • center:与交叉轴的中点对齐。
  • space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
  • space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
  • stretch(默认值):轴线占满整个交叉轴。

今天先写到这, 明天再补子容器的配置

参考文档

相关推荐
加班是不可能的,除非双倍日工资4 小时前
css预编译器实现星空背景图
前端·css·vue3
wyiyiyi4 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
gnip5 小时前
vite和webpack打包结构控制
前端·javascript
excel5 小时前
在二维 Canvas 中模拟三角形绕 X、Y 轴旋转
前端
阿华的代码王国5 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
一条上岸小咸鱼5 小时前
Kotlin 基本数据类型(三):Booleans、Characters
android·前端·kotlin
Jimmy5 小时前
AI 代理是什么,其有助于我们实现更智能编程
前端·后端·ai编程
ZXT6 小时前
promise & async await总结
前端
Jerry说前后端6 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化
画个太阳作晴天6 小时前
A12预装app
linux·服务器·前端