【移动Web开发 | 移动端常见布局】flex布局

思维导图

图1

一:传统布局与flex布局

flex 是 flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性,任何一个容器都可以指定为 flex 布局。

  1. 当我们为父盒子设为 flex 布局以后,子元素的 float、clear 和 vertical-align 属性将失效。
  2. 伸缩布局 = 弹性布局 = 伸缩盒布局 = 弹性盒布局 =flex布局
  3. PC端:用传统布局
  4. 移动端:用flex布局

❦给父盒子添加flex属性来控制子盒子的位置和排列方式

二:flex布局父项常见属性

display:flex; 开启flex布局

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

主轴和侧轴是会变化的,就看 flex-direction 设置谁为主轴,剩下的就是侧轴。而我们的子元素是跟着主轴来排列的,在主轴上一行显示

属性 描述
row 默认值从左到右(X轴方向)
row-reverse 从右到左
column 从上到下(Y轴方向)
column-reverse 从下到上

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

属性 描述
flex-start 默认值从头部开始,如果主轴是x轴,则从左到右
flex-end 从尾部开始排列
center 在主轴居中对齐(如果主轴是x轴则水平居中)
space-around 平分剩余空间
space-between 先两边贴边再平分剩余空间((重要)
space-evenly 平均分配

❀ 区别space-around,space-between,space-evenly

  • space-around
 /* 开启flex布局 */
 display: flex;
/* space-around|平分剩余空间 */
 justify-content: space-around;

图2

  • space-between
/* 开启flex布局 */
 display: flex;
/* space-between|先两边贴边再平分剩余空间((重要) */
justify-content: space-between;

图3

  • space-evenly
/* 开启flex布局 */
display: flex;
/* space-evenly|平均分配 */
justify-content: space-evenly;

在这里插入图片描述

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

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

属性 描述
nowrap 默认值,不换行
wrap 换行

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

该属性是控制子项在侧轴(默认是y轴)上的排列方式在子项为单项(单行)的时候使用

扫描二维码关注公众号,回复: 12272281 查看本文章
属性 描述
flex-start 默认值从上到下
flex-end 从下到上
center 挤在一起居中(垂直居中)
stretch 拉伸

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

设置子项在侧轴上的排列方式并且只能用于子项出现换行的情况(多行),在单行下是没有效果的。

属性 描述
flex-start 默认值在侧轴的头部开始排列
flex-end 在侧轴的尾部开始排列
center 在侧轴中间显示
space-around 子项在侧轴平分剩余空间
space-between 子项在侧轴先分布在两头,再平分剩余空间
stretch 设置子项元素高度平分父元素高度

❀ align-content 和 align-items 区别

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

2.6:flex-flow

flex-flow 属性是 flex-direction 和 flex-wrap 属性的复合属性

三:flex布局子项常见属性

3.1:flex

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

flex: <number>; 

【叽叽歪歪】设置了flex以后,子标签表示主轴空间的样式就不起作用了

3.2 align-self

align-self 属性允许单个项目有与其他项目不一样的对齐方式,可覆盖 align-items 属性。
默认值为 auto,表示继承父元素的 align-items 属性,如果没有父元素,则等同于 stretch。

3.3:order

属性定义项目的排列顺序

四:背景线性渐变

background: linear-gradient(to bottom, red, pink);

图5
【叽叽歪歪】没得案例,找不到☢

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_43490212/article/details/109822001