您现在的位置是:网站首页> 编程资料编程资料
深入剖析CSS弹性盒模型flex实例讲解CSS3中的box-flex弹性盒属性布局CSS3弹性盒模型flex box快速入门心得(必看篇)CSS弹性盒模型flex在布局中的应用详解几个CSS3的flex弹性盒模型布局的简单例子演示基础的CSS3弹性盒Flexbox布局使用实例css3弹性盒模型(Flexbox)详细介绍css flex 弹性布局详解
2021-09-05
1003人已围观
简介 下面小编就为大家带来一篇深入剖析CSS弹性盒模型flex。小编觉得挺不错的,现在分享给大家,也给大家做一个参考。一起跟随小编过来看看吧
CSS3引入了一种新的布局模型——flex布局。flex是flexible box的缩写,一般称之为弹性盒模型。和CSS3其他属性不一样,flexbox并不是一个属性,而是一个模块,包括多个CSS3属性。flex布局提供一种更加有效的方式来进行容器内的项目布局,以适应各种类型的显示设备和各种尺寸的屏幕
版本更迭 flexbox布局的语法规范经过几年发生了很大的变化。从2007年07月,flex第一版本的工作草案发布,到2012年09月,flex最新版本成为候选推荐。flex主要经历了三个版本
【1】旧版本 display:box | inline-box;
该版本IE浏览器不支持,且其他浏览器和移动端都需要添加前缀,但移动端可以兼容到andriod2.1和ios3.2
【2】混合版本 display:flexbox | inline-flexbox;
该版本只有IE10支持,且需要添加前缀-ms-
【3】新版本 display: flex | inline-flex
该版本兼容IE11+、firefox、safari、chrome、opera及移动端,但移动端ios7.1-8.4需要添加前缀-webkit-
display要让一个元素变成伸缩容器,需要使用display属性。采用flex布局的元素,称为伸缩容器(flex container),容器内的子元素称为伸缩项目(flex item)
[注意]浏览器会将任何直接在伸缩容器里的连续文字块包起来成为匿名伸缩项目
使用flex布局实现上是使元素FFC化(flex formatting context伸缩格式化上下文),FFC是普通流的一种。而浮动流和定位流以及CSS其他属性对FFC是有影响的,主要表现在以下几点:
[1]float、clear和vertical-align属性在伸缩项目上没有效果
[2]伸缩容器的margin与其内容的margin不会重叠
[3]text-align属性在伸缩容器上没有效果,因为其只可应用于块级block容器
[4]另外,conlumns属性伸缩容器上没有效果
弹性盒模型的两种容器块级伸缩容器和内联伸缩容器的区别类似于block和inline-block的区别,一个独占一行,另一个非独占一行
- //弹性盒模型: 块级伸缩容器 | 内联伸缩容器
- //新版本
- display: flex | inline-flex;
- //混合版本
- display: flexbox | inline-flexbox;
- //旧版本
- display: box | inline-box;
基本概念
伸缩容器默认存在两条轴: 水平的主轴(main axis) 和垂直的侧轴(cross axis)
[注意]主轴方向不一定是水平的,它主要取决于justify-content属性
主轴起点叫main start,主轴终点叫main end;侧轴起点叫cross start,侧轴终点叫cross end
伸缩项目默认沿主轴排列。单个伸缩项目占据的主轴空间叫main size ,占据的侧轴空间叫cross size
[注意]伸缩项目的main size和cross size主要由宽度或高度决定
伸缩容器以下6个属性作用在伸缩容器上
伸缩流方向 flex-direction
伸缩流换行 flex-wrap
伸缩流(包括方向与换行) flex-flow
主轴对齐 justify-content
侧轴对齐 align-items
堆栈伸缩行 align-content
【1】伸缩流方向:指定主轴的方向(即伸缩项目在伸缩容器中的排列方向)
- //伸缩流方向: 水平方向 | 反向水平 | 垂直方向 | 反向垂直
- //新版本同混合版本
- flex-direction: row[默认] | row-reverse | column | column-reverse
- //旧版本
- box-orient: horizontal(水平) |vertical(垂直) |inline-axis[默认](内联轴方向) |block-axis(块级轴方向)
- box-direction: normal(正常) | reverse(反向)
[注意]伸缩流方向与direction和wrinting-mode有关系
【2】伸缩流换行:指定伸缩项目溢出伸缩容器时是否换行
- //伸缩行换行:不换行 | 换行 | 反转换行
- //新版本同混合版本
- flex-wrap: nowrap[默认] | wrap | wrap-reverse
- //旧版本,没有浏览器支持box-lines属性,所以在旧版本中无法实现伸缩项目换行显示
- box-lines: single[默认] | multiple | N/A
[注意]此时,CSS允许使用overflow属性来处理溢出内容的显示方式
[注意]伸缩项目的排列顺序同样与direction和wrinting-mode有关系
【3】伸缩流:伸缩流方向与伸缩行换行的缩写
- //伸缩流: 伸缩流方向 | 伸缩行换行
- //新版本同混合版本
- flex-flow:
direction> | - [默认值] flex-flow: row nowrap
- //旧版本无对应属性
【4】主轴对齐:用来设置伸缩容器当前行伸缩项目在主轴方向的对齐方式,指定如何在伸缩项目之间分布伸缩容器额外空间
当一行上的所伸缩项目不能伸缩或可伸缩已达到最大长度时,这一属性才会对伸缩容器额外空间进行分配。当伸缩项目溢出某一行时,这一属性也会在项目的对齐上施加一些控制
- //主轴对齐方式: 左对齐 | 居中对齐 | 右对齐 | 两端对齐 | 扩散对齐
- //新版本
- justify-content: flex-start[默认] | center | flex-pack | flex-end | space-around
- //混合版本
- flex-pack: start[默认] | center | end | justify | distribute
- //旧版本
- box-pack: start[默认] | center | end | justify | N/A
[注意]主轴对齐方式与direction、writing-mode、flex-flow都有关
【5】侧轴对齐:用来设置伸缩容器当前行在侧轴方向的对齐方式
- //侧轴对齐方式: 顶边对齐 | 中间对齐 | 底部对齐 | 基线对齐 | 伸缩项目拉伸填充整个伸缩容器
- //新版本
- align-items: flex-start | center | flex-end | baselinebaseline | stretch[默认]
- //混合版本
- flex-align: start | center | end | baselinebaseline | stretch[默认]
- //旧版本
- box-align: start | center | end | baselinebaseline | stretch[默认]
[注意]如果伸缩项目有width/height属性将优先于侧轴对齐为拉伸的方式
[注意]侧轴对齐方式与direction、writing-mode、flex-flow都有关
【6】堆栈伸缩行:指定多个伸缩项目行在侧轴的对齐方式
- //侧轴对齐方式: 顶边对齐 | 中间对齐 | 底部对齐 | 两端对齐 | 扩散对齐 | 伸缩项目拉伸填充整个伸缩容器
- //新版本
- align-content: flex-start | center | flex-end | space-between | space-around | stretch[默认]
- //混合版本
- flex-line-pack: start | center | end | justify | distribute | stretch[默认]
- //旧版本无对应属性
[注意]该属性只有在flex-wrap:wrap | wrap-reverse;且伸缩项目存在多行时才生效
[注意]堆栈伸缩行与direction、writing-mode、flex-flow都有关
伸缩项目一个伸缩项目就是伸缩容器的一个子元素。伸缩容器中的文本也被视为一个伸缩项目。以下6个属性设置在伸缩项目上。
自身侧轴对齐方式 align-self
伸缩基准值 flex-basis
扩展比率 flex-grow
收缩比率 flex-shrink
伸缩性 flex
显示顺序 order
【1】自身侧轴对齐方式:单个伸缩项目在侧轴的对齐方式,该属性可以覆盖伸缩容器的侧轴对齐方式
[注意]对于匿名伸缩项目,align-self的值永远与其关联的伸缩容器的align-items的值相同
- //侧轴对齐方式: 自动 | 顶边对齐 | 中间对齐 | 底部对齐 | 基线对齐 | 伸缩项目拉伸填充整个伸缩容器
- //新版本
- align-self: auto[默认] | flex-start | center | flex-end | baselinebaseline | stretch
- //混合版本
- flex-item-align: auto[默认] | start | center | end | baselinebaseline | stretch
- //旧版本无对应属性
[注意]如果align-self的值为auto,则其计算值为伸缩项目的伸缩容器的align-items值
[注意]如果伸缩项目的任一个侧轴上的外边距为auto,则该伸缩项目在伸缩容器的剩余空间内居中对齐,且align-self没有效果。
【2】伸缩基准值: 伸缩项目在主轴方向上的初始大小
- //新版本
- flex-basis:
| auto[默认] - //混合版本
- positive-flex:
[默认为1] - //旧版本无对应属性
如果flex-basis的值为0,表示伸缩项目在主轴方向上的初始大小为0,则分配所有空间;如果flex-basis的值为auto,表示伸缩项目在主轴方向上的初始大小为其本身的大小,则分配剩余空间
[注意]flex-basis的
【3】扩展比率: 当伸缩容器的额外空间为正值时,此伸缩项目相对伸缩容器里其他伸缩项目能扩展的空间比例
- //新版本
- flex-grow:
[默认为0] - //混合版本
- positive-flex:
[默认为0] - //旧版本无对应属性
若flex-grow的值为0表示即使存在剩余空间也不放大;若所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话);若一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍
【4】收缩比率:当伸缩容器的额外空间为负值时,此伸缩项目相对于伸缩容器里其他伸缩项目能收缩的空间比例
- //新版本
- flex-shrink:
[默认为1] - //混合版本
- negative-flex:
[默认为0] - //旧版本无对应属性
如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。
[注意]伸缩基准值、扩展比率和收缩比率都可以为小数,但不能为负数
【5】伸缩性:是扩展比率、收缩比率和伸缩基准值的缩写
- flex: none => flex: 0 0 auto;
- flex: auto => flex: 1 1 auto;
- flex: 0 => flex: 0 1 0%;
- flex: 1 => flex: 1 1 0%;
- flex: 0
相关内容
- CSS3弹性盒模型开发笔记(二) CSS盒模型制定网页的宽度和高度的原理-CSS教程-网页制作-网页教学网CSS教程:盒模型(BOX Model)-CSS教程-网页制作-网页教学网CSS入门教程:计算CSS盒模型宽和高-CSS教程-网页制作-网页教学网掌握盒模型轻松DIV CSS网页布局CSS教程:通过实例学习和理解CSS盒模型CSS教程之CSS盒模型网页设计学习教程 CSS盒模型css盒模型和块级、行内元素深入理解css3弹性盒模型实例介绍css3弹性盒模型(Flexbox)详细介绍
- CSS3色彩模式有哪些?CSS3 HSL色彩模式的定义CSS3常用的几种颜色渐变模式总结利用CSS3把图片变成灰色模式的实例代码什么是CSS3 HSLA色彩模式?HSLA模拟渐变色条CSS3 RGBA色彩模式使用实例讲解使用CSS实现黑暗模式和高亮模式的切换功能
- 利用CSS中linear制作复杂的边框效果CSS3实现超酷的黑猫警长首页CSS3实现千变万化的文字阴影text-shadow效果设计什么是CSS3 HSLA色彩模式?HSLA模拟渐变色条CSS3 RGBA色彩模式使用实例讲解CSS3不透明度实例讲解CSS3色彩模式有哪些?CSS3 HSL色彩模式的定义深究CSS定位position的常用技法探究CSS边框特效实现技巧CSS实现弹簧效果的旋转加载动画CSS实现大小相同、颜色深浅不一的粒子旋转加载动画
- 探究CSS边框特效实现技巧CSS3实现超酷的黑猫警长首页CSS3实现千变万化的文字阴影text-shadow效果设计什么是CSS3 HSLA色彩模式?HSLA模拟渐变色条CSS3 RGBA色彩模式使用实例讲解CSS3不透明度实例讲解CSS3色彩模式有哪些?CSS3 HSL色彩模式的定义利用CSS中linear制作复杂的边框效果深究CSS定位position的常用技法CSS实现弹簧效果的旋转加载动画CSS实现大小相同、颜色深浅不一的粒子旋转加载动画
- CSS实现弹簧效果的旋转加载动画CSS控制前端图片HTTP请求的各种情况示例css全屏背景图片设置,django加载图片路径详解纯CSS3实现的绿色Loading加载动画特效源码jQuery+css3实现的点击下载按钮3D加载downlading进度特效源码CSS实现大小相同、颜色深浅不一的粒子旋转加载动画CSS实现圆环旋转加载动画CSS实现横向粒子变动加载动画CSS3实现粒子旋转伸缩加载动画深入解析动态加载css的实现方法
- CSS实现大小相同、颜色深浅不一的粒子旋转加载动画CSS控制前端图片HTTP请求的各种情况示例css全屏背景图片设置,django加载图片路径详解纯CSS3实现的绿色Loading加载动画特效源码jQuery+css3实现的点击下载按钮3D加载downlading进度特效源码CSS实现弹簧效果的旋转加载动画CSS实现圆环旋转加载动画CSS实现横向粒子变动加载动画CSS3实现粒子旋转伸缩加载动画深入解析动态加载css的实现方法
- CSS实现圆环旋转加载动画css制作收缩圆环旋转效果实例代码css3 clip实现圆环进度条的示例代码图解CSS3制作圆环形进度条的实例教程实现CSS圆环的5种方法(小结)
- CSS实现横向粒子变动加载动画CSS控制前端图片HTTP请求的各种情况示例css全屏背景图片设置,django加载图片路径详解纯CSS3实现的绿色Loading加载动画特效源码jQuery+css3实现的点击下载按钮3D加载downlading进度特效源码CSS实现弹簧效果的旋转加载动画CSS实现大小相同、颜色深浅不一的粒子旋转加载动画CSS实现圆环旋转加载动画CSS3实现粒子旋转伸缩加载动画深入解析动态加载css的实现方法
- 自适应屏幕的CSS响应式布局设计技巧总结
- CSS3实现大小不一的粒子旋转加载动画CSS3绘制超炫的上下起伏波动进度加载动画使用Loader.css和css-spinners来制作加载动画的方法一款利用纯css3实现的win8加载动画的实例分析使用css3实现的windows8开机加载动画实例教程 纯CSS3打造非常炫的加载动画效果一款纯css3实现的动画加载导航使用css3实现超炫的loading加载动画效果通过css加载远程字体示例代码css 样式加载的优先级使用经验分享css外部样式加载Link与import的区别
点击排行
本栏推荐
