网站首页 > 技术文章 正文
学海无涯,不要沉浸在知识的海洋里,迷失自己。
要知道自己想要什么,抓住重点,不忘初心。
这个世界上百分之20的人,掌握着百分之80的财富。
接下来一系列教程,就带领大家抓住重点,一起做那百分之20的人。
往期知识点回顾:
一. flex 解释
1、flex 布局 为 flexible BOX 的缩写 ,意思为 弹性布局。
2、块级元素和行内块级元素都可以使用flex布局。
3、Webkit内核的浏览器,需要加上-webkit前缀。
二. flex 容器属性
1、flex-direction
此属性决定主轴的方向
.flex{
flex-direction: row; // (默认值) 主轴水平方向,从左往右
flex-direction: row-reverse; // 主轴水平方向的逆方向,从右往左
flex-direction: column; // 主轴为垂直方向,从上往下
flex-direction: column-reverse; // 主轴为垂直方向的逆方向,从下往上
}
复制代码
2、flex-wrap
此属性定义,如果一条轴线上排列不下,换行的方式
.flex{
flex-wrap: nowrap; // (默认)不换行
flex-wrap: wrap; // 正常换行 从上到下
flex-wrap: wrap-reverse; // 逆方向换行 从下到上
}
复制代码
3、flex-flow
此属性定义,是flex-direction和flex-wrap简写的方式;
.flex {
flex-flow: <flex-direction> 空格 <flex-wrap>;
}
复制代码
4、justify-content
此属性定义,项目在主轴上的对齐方式
.flex{
justify-content: flex-start; // 左对齐(默认)
justify-content: flex-end; // 右对齐
justify-content: center; // 居中
justify-content: space-between; // 两端对齐。且项目间间隔相等
justify-content: space-around; // 每个项目两侧间隔相等,所以项目间 间隔 比项目与边框间间隔大一倍
justify-content: space-evenly; // 项目间间隔与项目与边框间 间隔均匀分配
}
复制代码
5、align-items
此属性定义,项目在交叉轴上的对齐方式
.flex{
align-items: flex-start; // 交叉轴的起点对齐
align-items: flex-end; // 交叉轴的终点对齐
align-items:center; // 交叉轴的中点对齐
align-items: baseline; // 项目的第一行文字的基线对齐
align-items: stretch; // (默认值) 如果项目未设置高度或设为auto ,将充满整父级容器高度
}
复制代码
6、align-content
此属性定义,多个项目多根轴线的对齐方式,只有一个轴线时没有作用
.flex{
align-content: flex-start; // 与交叉轴的起点对齐。
align-content: flex-end:// 与交叉轴的终点对齐。
align-content: center:// 与交叉轴的中点对齐。
align-content: space-between:// 与交叉轴两端对齐,轴线之间的间隔平均分布。
align-content: space-around:// 每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
align-content: stretch; // (默认值)轴线占满整个交叉轴。
}以上的属性都是容器的属性
复制代码
三. flex 项目 属性
1、order
此属性决定项目的排列顺序,数值越小。排列越靠前。
.box{
order: number; // 默认为 0 ,要讲哪个项目向前移动 将其order设置为负数。
}
复制代码
2、flex-grow
此属性决定项目的放大比例。
.box{
flex-grow: 5; // 默认为 0
}
复制代码
3、flex-shrink
此属性决定项目的缩小比例。
.item {
flex-shrink: number; // 默认为1.要将哪个项目缩小 值设为0 ;
}
复制代码
4、flex-basis
此属性定义 在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小。
5、flex
此属性定义为 flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。
.item{
flex: flex-grow flex-shrink flex-basis; // 简写方式
}
复制代码
5、align-self
此属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。
.item{
align-self: auto;
align-self: flex-start;
align-self: flex-end;
align-self: center;
align-self: baseline;
align-self: stretch;
}
复制代码
四. 代码实践练习
github 地址:
https://github.com/zjycpzjy/cssFlexbox.git
五.flex布局面试题
谈谈对flex布局的认识
web应用有不同设备尺寸和分辨率,这时需要响应式界面设计来满足复杂的布局需求,Flex弹性盒模型的优势在于开发人员只是声明布局应该具有的行为,而不需要给出具体的实现方式,浏览器负责完成实际布局。
当布局涉及到不定宽度,分布对齐的场景时,就要优先考虑弹性盒布局。
- 上一篇: Vue书组件设计与实现详解
- 下一篇: 每天一个CSS小技巧 - 不规则投影
猜你喜欢
- 2025-05-26 【HarmonyOS Next之旅】兼容JS的类Web开发 -> 常见组件(一)
- 2025-05-26 每天一个CSS小技巧 - 不规则投影
- 2025-05-26 Vue书组件设计与实现详解
- 2025-05-26 CSS Viewport 单位,很多人还不知道使用它来快速布局
- 2025-05-26 宁静清晨!两道 CSS 面试题,助你从容应对职场挑战
- 2025-05-26 如何使用CSS实现旋转地球动画效果
- 2025-05-26 【HarmonyOS Next之旅】兼容JS的类Web开发(五) -> Svg
- 2025-05-26 CSS超炫加载动画设计、实现与实例讲解
- 2025-05-26 垂直居中方法大全
- 2025-05-26 分享几个漂亮的宇宙风格的按钮动画效果,让你喜欢上CSS
- 最近发表
-
- 用Cursor开启JAVA+AI生涯_javascirpt怎么开启
- 大数据调度服务监控平台_大数据调度是什么意思
- SpringBoot、MyBatis、Vue搭建一个Java企业应用开源框架源码分享
- 大数据技术之Flume_大数据volume的含义
- Jenkins运维之路(Slave容器节点)_jenkins slave工作原理
- 程序员自救指南:IDEA 卡成狗?我的 9G 堆内存调参表让你起飞 附避坑
- JMeter:一个简单的测试计划怎么做?
- Windows 命令行终端 PowerShell 美化计划
- JDK25即将发布!新特性概览_jdk52.0
- JDK 25 新特性极简总结(2025 年 9 月 16 日发布,LTS 长期支持)
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (77)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)