css层叠样式表flex弹性盒模型

1. 简介

Flex是Flexible Box的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性.

任何一个容器都可以指定Flex布局.

采用Flex布局的元素,称为Flex容器(flex container),简称”容器”.它的所有子元素自动称为容器成员,称为Flex项目(flex item),简称”项目”.

css层叠样式表flex弹性盒模型

注意:
box层没有设置高度,设置了display:flex,所以flex里的项目是不脱离文档流的

css层叠样式表flex弹性盒模型

flex里的项目,总宽度如果不超过父级宽度,那么就正常横向排列

flex里的项目,总宽度如果超过父级宽度,那么加给项目的宽度就无效了,每个项目的宽度会自动均分

css层叠样式表flex弹性盒模型

2. 基本概念

css层叠样式表flex弹性盒模型

容器默认存在两根轴:水平的主轴(main axis)和垂直的交叉轴(cross axis)。主轴的开始位置(与边框的交叉点)叫做main start,结束位置叫做main end;交叉轴的开始位置叫做cross start,结束位置叫做cross end。

项目默认沿主轴排列。单个项目占据的主轴空间叫做main size,占据的交叉轴空间叫做cross size。

3. 容器的属性

以下6个属性设置在容器上。

 

u flex-direction

u flex-wrap

u flex-flow

u justify-content

u align-items

u align-content

3.1. flex-direction属性

flex-direction属性决定主轴的方向(即项目的排列方向)。

取值:

row(默认值):主轴为水平方向,起点在左端。

css层叠样式表flex弹性盒模型

row-reverse:主轴为水平方向,起点在右端。

css层叠样式表flex弹性盒模型
column:主轴为垂直方向,起点在上沿。

css层叠样式表flex弹性盒模型
column-reverse:主轴为垂直方向,起点在下沿。

css层叠样式表flex弹性盒模型

3.2. flex-wrap属性

默认情况下,项目都排在一条线(又称"轴线")上。flex-wrap属性定义,如果一条轴线排不下,如何换行。

取值:

nowrap(默认):不换行。

css层叠样式表flex弹性盒模型

wrap(常用):换行,第一行在上方。

css层叠样式表flex弹性盒模型

wrap-reverse:换行,第一行在下方。

css层叠样式表flex弹性盒模型
3.3. flex-flow属性

flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。

css层叠样式表flex弹性盒模型
3.4. justify-content属性

justify-content属性定义了项目在主轴上的对齐方式。

它可取5个值,具体对齐方式与轴的方向有关。下面假设主轴为从左到右。

flex-start(默认值):左对齐

css层叠样式表flex弹性盒模型

flex-end:右对齐

css层叠样式表flex弹性盒模型

center: 居中

css层叠样式表flex弹性盒模型

space-between(最常用):两端对齐,项目之间的间隔都相等。

css层叠样式表flex弹性盒模型

space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍

css层叠样式表flex弹性盒模型

3.5. align-items属性
align-items属性定义项目在交叉轴上如何对齐。

它可取5个值。具体的对齐方式与交叉轴的方向有关,下面假设交叉轴从上到下。

flex-start:交叉轴的起点对齐。

css层叠样式表flex弹性盒模型

flex-end:交叉轴的终点对齐。

css层叠样式表flex弹性盒模型

center:交叉轴的中点对齐。

css层叠样式表flex弹性盒模型

baseline: 项目的第一行文字的基线对齐。

css层叠样式表flex弹性盒模型

stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。

先来看看没有给项目设置高度的时候,并且align-items为flex-start的时候的效果
css层叠样式表flex弹性盒模型

align-items:stretch时

css层叠样式表flex弹性盒模型

3.6. align-content属性

align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。

该属性可取6个值。

flex-start:与交叉轴的起点对齐。

css层叠样式表flex弹性盒模型

flex-end:与交叉轴的终点对齐。

css层叠样式表flex弹性盒模型

center:与交叉轴的中点对齐。

css层叠样式表flex弹性盒模型

space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。

css层叠样式表flex弹性盒模型

space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。

css层叠样式表flex弹性盒模型

stretch(默认值):轴线占满整个交叉轴,前提是项目没有设置高度,否则效果跟align-content:flex-start效果一样

css层叠样式表flex弹性盒模型

css层叠样式表flex弹性盒模型

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/6477.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2018年4月27日 10:17
下一篇 2018年4月27日 10:36

相关推荐

  • 聊聊css的三种引入方式及优先级。

    CSS引入的方式有以下几种: 1. 内联样式(Inline Style):在HTML元素的”style”属性中直接写入CSS代码,这种方式的优先级最高,但不利于代码的复用和维护。 2. 内部样式表(Internal Style Sheet):在…

    2024年6月28日
    00
  • 今日分享html如何裁剪图片。

    在HTML中裁剪图片通常需要借助CSS或者JavaScript来实现,由于HTML本身并不支持图像裁剪功能,我们需要利用上述技术手段来控制图片显示的部分,从而达到裁剪的效果,以下是几种常见的方法: (图片来源网络,侵删) …

    2024年6月26日
    00
  • 小编分享css调用动画。

    在Destoon中调用CSS,我们主要通过修改模板中的样式表来实现,你需要在你的Destoon后台管理系统中找到对应的模板文件,然后在其中插入你的CSS代码。 以下是具体的步骤: 1. 登录Destoon后台管理系统,找到你需要修…

    2024年7月2日
    00
  • 2019年网站开发的八大趋势。

    熟悉前端开发的人应该都知道,最近几年,各种前端框架层出不从,H5开发模式也越来越流行,大前端时代也已经到来。每一年各种前端技术也应运而生,快速掌握最新的前端技术也是每一个开发者不可或缺的一门技能。如今…

    2022年7月4日
    0116
  • css+div布局学习路线!

    自学CSS+DIV布局步骤 一、认清目的 首先要认识为什么要学习CSS,知道学习CSS目的是什么。 认识学习目的才能坚持持之以恒、认识学习目的才有目的性从中得到乐趣和享受! 二、基础学习 1、了解CSS作用是什么? 2、css…

    2017年11月7日
    0208
  • 使用css的border属性实现三角形

    使用css的border属性实现三角形 1. border使用方法 2. border 三角形 2.1. 三角形原理,我们来看一个普通的底部边框 2.2. 我们在右边添加一个边框,细心留意两个border的交界就是一个斜线 2.3. 我们在左边边添加一…

    2018年5月7日 css自学教程
    0607
  • 经验分享css中的flex布局。

    Flex布局是CSS的一个重点应用。它可以简便、完整、响应式地实现各种页面布局。Flex布局的目标是提供一个更有效地布局、对齐方式,并且能够使父元素在子元素的大小未知或动态变化情况下仍然能够分配好子元素之间的间…

    2024年7月18日
    00
  • 经验分享html如何填充背景图。

    在HTML中,可以使用CSS(层叠样式表)来填充背景图,以下是详细步骤: (图片来源网络,侵删) 1、你需要准备一张你想要作为背景的图片,确保图片的尺寸适合你的网页设计,并且图片的文件格式是浏览器支持的,如.jp…

    2024年6月25日
    00

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息