前言

CSS3新增了弹性盒子模型( Flexible Box或ElexBox),是-种新的用于在HTML页面实现布局的方式。使得当HTML页面适应不同尺寸的屏幕和不同的设备时,元素是可预测地运行。
弹性盒子模型实现HTML页面布局是与方向无关的。不类似于块级布局侧重垂直方向,内联布局侧重水平方向。
弹性盒子模型主要适用于HTML页面的组件以及小规模的布局,而并不适用于大规模的布局,否则会影响HTML页面性能。

正文

1.什么是弹性盒子模型

弹性盒子是 CSS3 的一种新的布局模式

是一种当页面需要适应不同的屏幕大小以及设备类型时 确保元素拥有恰当的行为的布局方式

引入弹性盒布局模型的目的是提供一种更加有效的方式来对一个容 器中的子元素进行排列、对齐和分配空白空间

2.弹性盒子内容

  1. 伸缩容器( flex container) :包裹伸缩项目的父元素。

  2. 伸缩项目( flex item) :伸缩容器的每个子元素。

  3. 轴(axis) :每个弹性盒子模型拥有两个轴。                                                                                             主轴(main axis) :伸缩项目沿其-次排列的轴被称为主轴。                                                         侧轴(cross axis) :垂直于主轴的轴被称为侧轴。

  4. 方向(direction) :伸缩容器的主轴由主轴起点和主轴终点,侧轴由侧轴起点和侧轴终点描述伸缩项目排列的方向。

  5. 尺寸( dimension) :根据伸缩容器的主轴和侧轴,伸缩项目的宽度和高度。对应主轴的称为主轴尺寸。对应侧轴的称为侧轴尺寸。

3.创建弹性盒子

css3中通过display样式属性设置弹性盒子模型:

 display: flex;display: inline-flex;

按照上述示例代码设置指定元素为弹性盒子模型,该元素成为伸缩容器,其子元素则成为伸缩项目。

  • flex: 设置指定元素为块级元素的弹性盒子模型。
  • inline-flex: 设置指定元素为行内块级元素的弹性盒子模型。

弹性盒子模型样式如下:

<style>/* 为父级容器元素设置display为flex值* 表示当前元素及其所有子元素就是弹性盒子模型* 默认情况下,所有子元素作为伸缩项目(沿着主轴进行排列)*/.container{display : inline-flex;}.container div{width: 300px;height: 200px;}.container div:nth-child(1){background-color: yellow;}.container div:nth-child(2){background-color: green;}.container div:nth-child(3){background-color: blue;}</style><body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container"><div></div><div></div><div></div></div>
</body>

效果:


四.弹性盒子模型的属性

1、flex-direction属性:布局方向

CSS flex-direction属性适用于伸缩容器元素,用于创建主轴的方向。

flex-direction: row| row-reverse | column | column-reverse
  • row:设置主轴是水平方向。
  • row-reverse: 与row的排列方向相反。
  • column: 设置主轴是垂直方向。
  • column-reverse: 与column的排列方向相反。

示例:

flex-direction: row;           /*表示容器内容的布局方式为水平方向,从最左端开始,从左往右*/
flex-direction: row-reverse;   /*表示容器内容的布局方式为水平方向,从最右端开始,从右往左*/
flex-direction: column;        /*表示容器内容的布局方式为垂直方向,起点是上沿,从上往下*/
flex-direction: column-reverse;/*表示容器内容的布局方式为垂直方向,起点是下沿,从下往上*/

2、justify-content属性:对齐方式

CSS justify-content属性适用于伸缩容器元素,用于设置伸缩项目沿着主轴线的对齐方式。

justify-content: center | flex-start| flex-end | space between| space-around
  • center: 伸缩项目向第一行的中间位 置对齐。
  • flex-start:伸缩项目向第一行的开始位置对齐。
  • flex-end: 伸缩项目向第一行的结束位置对齐。
  • space-between: 伸缩项目会平均分布在一行中。
  • space-around:伸缩项目会平均分布在一行中 ,两端保留一半的空间

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>justify-content属性</title><style>.container{border: 1px solid black;margin-top: 10px;display: flex;           }/* justify-content属性作用 —— 设置伸缩项目在主轴上的对齐方式用法 —— 应用于伸缩容器元素 注意 —— 实现的是伸缩项目相对于伸缩容器的对齐方式*/.c1{/* flex-start —— 表示伸缩容器沿着主轴的起点对齐 */justify-content: flex-start;}.c2{/* center —— 表示伸缩容器沿着主轴的中间位置 */justify-content: center;}.c3{/* flex-end —— 表示伸缩容器沿着主轴的终点对齐 */justify-content: flex-end;}.c4{/* space-between —— 表示伸缩项目平均分配在伸缩容器中 */justify-content: space-between;}.c5{/* space-around—— 表示伸缩项目平均分配在伸缩容器中起点和终点位置多出了留白*/justify-content: space-around;}.container div{width: 200px;height: 100px; }.container div:nth-child(1){background-color: darkviolet;}.container div:nth-child(2){background-color: lightgreen;}.container div:nth-child(3){background-color: red;}</style>
</head>
<body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container c1"><div></div><div></div><div></div></div><div class="container c2"><div></div><div></div><div></div></div><div class="container c3"><div></div><div></div><div></div></div><div class="container c4"><div></div><div></div><div></div></div><div class="container c5"><div></div><div></div><div></div></div>
</body>
</html>

效果如下:

3、align-items属性:单根轴线对齐

CSS align-items属性适用于伸缩容器元素,用于设置伸缩项目所在行沿着侧轴线的对齐方式。

align-items: center| flex-start | flex-end | baseline | stretch
  • center: 伸缩项目向侧轴的中间位置对齐。
  • flex-start: 伸缩项目向侧轴的起点位置对齐。
  • flex- rend:伸缩项目向侧轴的终点位置对齐。
  • baseline: 伸缩项目根据伸缩项目的基线对齐。
  • stretch: 默认值,伸缩项目拉伸填充整个伸缩容器。

4、flex-wrap属性:环绕效果

CSS flex-wrap属性适用于伸缩容器元素,用于设置伸缩容器的子元素是单行显示还是多行显示。

flex-wrap: nowrap | wrap | wrap-reverse
  • nowrap: 设置伸缩项目单行显示。这种方式可能导致溢出伸缩容器。
  • wrap:设置伸缩项多行显示。
  • wrap-reverse:与wrap相反。

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>flex-wrap属性</title><style>.container{height: 200px;border: 1px solid black;margin-top: 10px;display: inline-flex;           }/* 如果设置伸缩容器的宽度小于所有子元素宽度之和的话:结果:* 子元素并没有自动换行,不等同于浮动效果( 自动换行)* 子元素并没有溢出.效果:根据伸缩容器的宽度自动调整所有子元索的宽度*/.c1{width: 500px;}/* flex-wrap属性作用:设置伸缩项目是单行显示还是多行显示用法:应用于伸缩容器元素值:nowrap:设置为单行显示,结果为根据伸缩容器的宽度自动调整所有子元素的宽度wrap:设置为多行显示结果为:1、如果伸缩容器的宽度大于所有子元素的宽度之和,单行显示2、如果伸缩容器的宽度小于所有子元素的宽度之和,多行显示(类似浮动)*/.c2{width: 500px;flex-wrap: nowrap;}.c3{width: 500px;flex-wrap: wrap;}.c4{width: 500px;/* 设置伸缩项多行显示的反向 */flex-wrap: wrap-reverse;}.container div{width: 200px;height: 100px; }.container div:nth-child(1){background-color: darkviolet;}.container div:nth-child(2){background-color: lightgreen;}.container div:nth-child(3){background-color: red;}</style>
</head>
<body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container c1"><div></div><div></div><div></div></div><div class="container c2"><div></div><div></div><div></div></div><div class="container c3"><div></div><div></div><div></div></div><div class="container c4"><div></div><div></div><div></div></div>
</body>
</html>

效果如下:

5、align-content属性:多根轴线的对齐方式

CSS align-content属性适用于伸缩容器元素,用于设置伸缩行的对齐方式。该属性会更改flex-
wrap属性的效果。

align-content: center | flex-start| flex-end I space-between I space around | stretch
  • center: 各行向伸缩容器的中间位置对齐。
  • flex-start:各行向伸缩容器的起点位置对齐。
  • flex-end:各行向伸缩容器的终点位置对齐。
  • space-between: 各行会平均分布在一行中。
  • space-around:各行会平均分布在一行中, 两端保留一半的空间。
  • stretch: 默认值,各行将会伸展以占用额外的空间

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>align-content属性</title><style>.container{height: 300px;border: 1px solid black;margin-top: 10px;width: 500px;display: inline-flex;    flex-wrap: wrap;       }/* align-content属性作用:设置多行显示伸缩项目,沿着侧轴的对齐方式注意:该属性对单行显示伸缩项目是无效的实现步骤:1、将伸缩项目设置为多行显示:flex—wrap:wrap;2、利用align-content属性进行对齐方式设置*/.c1{align-content: flex-start;}.c2{align-content: center;}.c3{align-content: flex-end;}.c4{align-content: space-between;}.c5{align-content: space-around;}.c6{align-content: stretch;}.container div{width: 200px;height: 100px; }.container div:nth-child(1){background-color: darkviolet;}.container div:nth-child(2){background-color: lightgreen;}.container div:nth-child(3){background-color: red;}</style>
</head>
<body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container c1"><div></div><div>c1</div><div></div></div><div class="container c2"><div></div><div>c2</div><div></div></div><div class="container c3"><div></div><div>c3</div><div></div></div><div class="container c4"><div></div><div>c4</div><div></div></div><div class="container c5"><div></div><div>c5</div><div></div></div><div class="container c6"><div></div><div>c6</div><div></div></div>
</body>
</html>

效果如下:

6、flex-flow属性

CSS flex- flow属性适用于伸缩容器元素,该属性是flex-direction和flex- wrap的简写。

flex-flow: <'flex-direction'>ll <'flex-wrap'>

五、flex属性

CSS flex属性是一个简写属性, 用于设置伸缩项目如何伸长或缩短以适应伸缩容器中的可用空间。

flex: auto | none| [ <'flex-grow'> <'flex -shrink'>? || <'flex-basis'> ]
  • auto: 伸缩项目会根据自身的宽度和高度确定尺寸,相当于将该属性设置为“flex: 11 auto”。
  • none:伸缩项目会根据自身的宽度和高度确定尺寸,相当于将该属性设置为“flex: 00 auto’
  • flex-grow:设置了一个flex项主尺寸的flex增长系数。它指定了flex容器中剩余空间的多少应该分配给项目(flex增长系数)。负值无效,默认为0。
  • flex -shrink:指定了 flex 元素的收缩规则。flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。负值是不被允许的。
  • flex-basis:指定了 flex 元素在主轴方向上的初始大小。如果不使用 box-sizing 改变盒模型的话,那么这个属性就决定了 flex 元素的内容盒(content-box)的尺寸。

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>flex属性</title><style>.container{height: 300px;border: 1px solid black;margin-top: 10px;   width: 500px; display: flex; }.container div{width: 200px;height: 100px; }.container div:nth-child(1){background-color: darkviolet;/* 不作任何处理 */flex: none;}.container div:nth-child(2){background-color: lightgreen;/* 自动填充父级容器元素中的所有空白空间 */flex: auto;}.container div:nth-child(3){background-color: red;/* flex-grow属性-伸缩项 目的拉伸因子值:<1 —— 所占区域小于等分=1 —— 与其他伸缩项目进行等分>1 —— 所占区域大于等分*/flex-grow: 1;}.container div:nth-child(4){background-color: blue;/* 该属性必须在所有子元素宽度之和大于容器的宽度时才有效 flex-shrink属性 —— 伸缩项目的收缩规则值:<1 —— 所占区域小于等分=1 —— 与其他伸缩项目进行等分>1  —— 所占区域大于等分*/flex-shrink: .5;}</style>
</head>
<body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container"><div></div><div></div><div></div><div></div></div>
</body>
</html>

效果:


 亦可使用flex属性实现简单的“定宽+自适应+定宽”三列布局:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>flex属性实现三列布局自适应</title><style>.container{height: 300px;border: 1px solid black;margin-top: 10px;   display: flex; }.container div{width: 200px;height: 100px; }.container div:nth-child(1){background-color: darkviolet;}.container div:nth-child(2){background-color: lightgreen;/* 非常简单的实现三列布局,定宽+自适应+定宽 */flex: auto;}.container div:nth-child(3){background-color: red;}</style>
</head>
<body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container"><div></div><div></div><div></div></div>
</body>
</html>


 三列等分布局:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>flex属性实现三列等分布局</title><style>.container{height: 300px;border: 1px solid black;margin-top: 10px;   display: flex; }.container div{width: 200px;height: 100px; /* 非常简单的实现等宽布局 */flex: 1;}.container div:nth-child(1){background-color: darkviolet;}.container div:nth-child(2){background-color: lightgreen;}.container div:nth-child(3){background-color: red;}</style>
</head>
<body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container"><div></div><div></div><div></div></div>
</body>
</html>


六、align-self属性

CSS align-self属性适用于伸缩容器元素,用于设置伸缩项目自元素在侧轴的对齐方式。

align-self: center| flex-start | flex-end | baseline| stretch
  • center: 伸缩项目向侧轴的中间位置对齐。
  • flex-start: 伸缩项目向侧轴的起点位置对齐。
  • flex-end: 伸缩项目向侧轴的终点位置对齐。
  • baseline: 伸缩项目根据伸缩项目的基线对齐。
  • stretch: 默认值,伸缩项目拉伸填充整个伸缩容器。

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>align-self属性</title><style>.container{height: 300px;border: 1px solid black;margin-top: 10px;   display: flex; }.container div{width: 200px;height: 100px; }.container div:nth-child(1){background-color: darkviolet;/* align-self属性作用:设置当前伸缩容器中具体某个伸缩项目在侧首的对齐方式用法:应用于伸缩项目的元素上*/align-self:flex-start}.container div:nth-child(2){background-color: lightgreen;align-self:center}.container div:nth-child(3){background-color: red;align-self:flex-end}.container div:nth-child(4){background-color: blue;align-self:baseline}.container div:nth-child(5){background-color: orange;align-self:stretch}</style>
</head>
<body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container"><div></div><div></div><div></div><div></div><div></div></div>
</body>
</html>


七、order属性

CSS order属性适用于伸缩项目,用于设置伸缩项目在布局时的顺序。

order: <integer>
  • integer: 表示当前伸缩项目所在的次序。

示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>order属性</title><style>.container{height: 300px;border: 1px solid black;margin-top: 10px;   display: flex; }.container div{width: 200px;height: 100px; }.container div:nth-child(1){background-color: darkviolet;/* order属性:设置伸缩项目的排列顺序*/order: 3;}.container div:nth-child(2){background-color: lightgreen;order: 1;}.container div:nth-child(3){background-color: red;order: 2;}</style>
</head>
<body><!-- 实现弹性盒子模型的HTML结构  -> 父级与子级的结构 --><div class="container"><div></div><div></div><div></div></div>
</body>
</html>


八 、页面中多媒体嵌入

1、视频

<video src="视频文件名" controls></video>
            视频的格式有:.mp4:mpeg-4(视频标准)     .Web M    .Ogg

2、音频

音频的格式有: .mp3 : mpeg-3(音频文件标准)  .wav     .ogg

九、CSS3中过渡效果

1、transition-property:指定过渡的属性,取值如下:
      
           none:没有属性取得过渡效果
           all : 所有属性都有过渡效果
           property:具体属性名获得过渡效果

transition-propeerty:background-color;/*指定背景颜色的过渡效果*/

2、 transition-duration:过渡效果所花费的时间

默认值为0                                                                                                                                          秒:单位是s                                                                                                                                        毫秒:单位是ms

3、transition-timing-function:过渡的速度曲线,取值如下:
     
              linear:以相同的速度从开始到结束。等同于cubic-bezier(0,0,1,1)
              ease:默认值。由慢到快,然后再到慢的效果
              ease-in:由慢开始,逐渐加快.即淡入效果
              ease-out:由慢结束.即淡出效果
              ease-in-out:淡入、淡出效果
              cubic-bezier(n,n,n,n):由函数实现



未完待续~~

CSS3-弹性盒子模型相关推荐

  1. css3弹性盒子模型之box-flex

    css3弹性盒子模型之box-flex 浏览器支持 目前没有浏览器支持 box-flex 属性. Firefox 支持替代的 -moz-box-flex 属性. Safari.Opera 以及 Chr ...

  2. css3的弹性盒子模型,css3弹性盒子模型——回顾。

    1.box-flex属性规定框的子元素是否可伸缩其尺寸. 父元素必须要声明display:box;子元素才可以用box-flex. 语法:box-flex:value; 示例: .test_box { ...

  3. css3弹性盒子模型之box-flex(--)

    今天看到蓝色理想上面有一篇文章讲<css3弹性盒模型布局模块介绍>里面讲到用box-flex,突然觉得有点心慌,上次看到响应式网页设计里面 也同样讲到flex box自适应布局,而上次竟然 ...

  4. CSS3 弹性盒子模型

    弹性盒子:flex布局 弹性盒子是一种布局方式 特点:改变元素的排列方式 采用flex布局的元素:称为flex容器,简称"容器".它的所有子元素自动成为容器成员,成为flex项目( ...

  5. CSS3弹性盒模型布局模块介绍

    来源:Robert's talk 原文:http://robertnyman.com/2010/12/02/css3-flexible-box-layout-module-aka-flex-box-i ...

  6. html弹性盒子垂直排列,css3弹性盒子布局

    css3弹性盒子布局 CSS3 弹性盒( Flexible Box 或 flexbox),是一种当页面需要适应不同的屏幕大小以及设备类型时确保元素拥有恰当的行为的布局方式. 引入弹性盒布局模型的目的是 ...

  7. html弹性盒子布局,div+css3弹性盒子(flex box)布局

    一.CSS3 弹性盒子(Flex Box) 弹性盒子是CSS3的一种新布局模式. CSS3 弹性盒( Flexible Box 或 flexbox),是一种当页面需要适应不同的屏幕大小以及设备类型时确 ...

  8. CSS3 弹性盒子和常用标签

    CSS3弹性盒子 学习目标 掌握CSS3弹性盒子的使用方法 掌握CSS3弹性盒子的水平分布方法 重点 掌握CSS3弹性盒子的垂直分布的方法 重点 掌握CSS3弹性盒子排序的用法 CSS3 弹性盒子属性 ...

  9. 微信小程序---弹性盒子模型

    1.弹性盒子布局 弹性盒子是 CSS3 的一种新的布局模式. CSS3 弹性盒( Flexible Box 或 flexbox),是一种当页面需要适应不同的屏幕大小以及设备类型时确保元素拥有恰当的行为 ...

  10. CSS3 弹性盒子(Flex Box)

    目录 CSS3 弹性盒子(Flex Box) 一.什么是 Flexbox >>> 了解两个基本概念,接下来会频繁提到: >>> 了解两个基本方向,这个牵扯到弹性布局 ...

最新文章

  1. 在T-SQL语句中访问远程数据库(openrowset/opendatasource/openquery)
  2. python-day2~3
  3. Julia OpenCV绑定简介
  4. 计算机图形学论文_论图计算
  5. 学习HttpClient,从两个小例子开始
  6. oracle安装很慢,oracle11g安装后电脑启动很慢怎么解决
  7. 想抛就抛:Application_Error中统一处理ajax请求执行中抛出的异常
  8. linux挂载windows上的共享文件夹
  9. 加密软件VMProtect入门教程
  10. STM32F103学习笔记(9)——NB-IoT模块BC26使用
  11. html用css美化表单登录页面
  12. 发票专用驱动sjz_【智能财税大讲堂】专用发票电子化的财税信息化变革
  13. python画三色柱状图_python画柱状图--不同颜色并显示数值的方法
  14. Python爬虫学习-简单爬取网页数据
  15. Java并发机制的底层实现原理--volatile
  16. 四、地址空间与内存分配
  17. mangos新手教程 - 服务器配置文件中文说明
  18. 关于微信小程序与Java后台交互数据中中文乱码问题的讨论
  19. 怎么把计算机模式重置,Windows10 WinRE模式下如何重置系统
  20. Codeforces - Bombs

热门文章

  1. PYTHON模块搜索路径
  2. rm -rf命令的作用 以及windows 代替命令
  3. linux-rm -f如何恢复
  4. 如何解决 Windows 实例出现身份验证错误
  5. 如何用matlab求函数的最值?
  6. 因影片里白人太多,Twitch平台撤下BLM视频
  7. 两种图像拼接(无重叠相邻图有重叠相邻图)以及matlab实现(边线查找法)
  8. 嵌入式软件开发为什么需要DevOps?
  9. Aspose.Cells.dll的运用
  10. 海思HI3559A SDK文档说明