Flex布局原理

1.布局原理

flex 是 flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性,任何一个容器都可以 指定为 flex 布局。
当我们为父盒子设为 flex 布局以后,子元素的 float、clear 和 vertical-align 属性将失效。
伸缩布局 = 弹性布局 = 伸缩盒布局 = 弹性盒布局 =flex布局

2.flex布局父项常见属性

flex-direction:

主轴和侧轴:

默认主轴是x轴方向,水平向右;

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

css 复制代码
    <style>
        div {
            /* 给父级添加flex属性 */
            display: flex;
            width: 800px;
            height: 300px;
            background-color: pink;
            /* 默认的主轴是 x 轴 行 row  那么y轴就是侧轴喽 */
            /* 我们的元素是跟着主轴来排列的 */
            /* flex-direction: row; */
            /* 简单了解 翻转 */
            flex-direction: row-reverse;
            /* 我们可以把我们的主轴设置为 y轴 那么 x 轴就成了侧轴 */
            flex-direction: column;
        }
        
        div span {
            width: 150px;
            height: 100px;
            background-color: purple;
        }
    </style>

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

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

属性值:no-wrap(换行)、wrap(默认值换行)

align-items

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

css 复制代码
div {
    display: flex;
    width: 800px;
    height: 400px;
    background-color: pink;
    /* 默认的主轴是 x 轴 row */
    flex-direction: column;
    justify-content: center;
    /* 我们需要一个侧轴居中 */
    /* 拉伸,但是子盒子不要给高度 
    /* align-items: stretch; */
    align-items: center;
    /* align-content: center; */
}

align-content

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

单行找align-item多行找align-conten

flex:属性定义子项目分配剩余空间,用flex来表示占多少份数

align-self:控制子项在自己在侧轴上的排列方式

order:定义项目的排列顺序

css 复制代码
  <style>
    section {
      display: flex;
      width: 60%;
      height: 150px;
      background-color: pink;
      margin: 100px auto;
      /* justify-content: center; */
      /* align-items: center; */
    }

    section div {
      background-color: purple;
      margin-right: 5px;
      width: 100px;
      height: 50px;
    }
    section div:nth-child(2) {
    /* 默认是0   -1比0小所以在前面 */
      order: -1;
      background-color: greenyellow;
    }
    section div:nth-child(3) {
      align-self: flex-end;
    }
  </style>

背景渐变必须添加浏览器私有前缀

css 复制代码
/* background: -webkit-linear-gradient(left, red, blue); */
/* background: -webkit-linear-gradient(red, blue); */
background: -webkit-linear-gradient(top left, rgb(22, 173, 67), rgb(71, 10, 212));
相关推荐
用户新10 分钟前
V8引擎 精品漫游指南--Ignition篇(上) 指令 栈帧 槽位 调用约定 内存布局 基础内容
前端·javascript
Next_Tech_AI14 分钟前
别用 JS 惯坏了鸿蒙
开发语言·前端·javascript·个人开发·ai编程·harmonyos
-凌凌漆-38 分钟前
【vue】选项式api与组合式api
前端·javascript·vue.js
0思必得02 小时前
[Web自动化] Selenium处理文件上传和下载
前端·爬虫·python·selenium·自动化·web自动化
phltxy3 小时前
Vue3入门指南:从环境搭建到数据响应式,开启高效前端开发之旅
前端·javascript·vue.js
小飞大王6663 小时前
CSS基础知识
前端·css
Charlie_lll3 小时前
学习Three.js–风车星系
前端·three.js
代码游侠3 小时前
学习笔记——Linux内核与嵌入式开发1
linux·运维·前端·arm开发·单片机·嵌入式硬件·学习
玩电脑的辣条哥3 小时前
幽灵回复AI已回复但前端不显示的排查与修复
前端·人工智能
石去皿4 小时前
轻量级 Web 应用 —— 把一堆图片按指定频率直接拼成视频,零特效、零依赖、零命令行
前端·音视频