• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > 深入剖析CSS弹性盒模型flex

深入剖析CSS弹性盒模型flex

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含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的区别,一个独占一行,另一个非独占一行

  1. //弹性盒模型: 块级伸缩容器 | 内联伸缩容器   
  2. //新版本   
  3. display: flex | inline-flex;   
  4. //混合版本   
  5. display: flexbox | inline-flexbox;   
  6. //旧版本   
  7. 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】伸缩流方向:指定主轴的方向(即伸缩项目在伸缩容器中的排列方向)

  1. //伸缩流方向: 水平方向 | 反向水平 | 垂直方向 | 反向垂直   
  2. //新版本同混合版本   
  3. flex-direction: row[默认] | row-reverse | column | column-reverse   
  4. //旧版本   
  5. box-orient: horizontal(水平) |vertical(垂直) |inline-axis[默认](内联轴方向) |block-axis(块级轴方向)   
  6. box-direction: normal(正常) | reverse(反向)  

[注意]伸缩流方向与direction和wrinting-mode有关系

【2】伸缩流换行:指定伸缩项目溢出伸缩容器时是否换行

  1. //伸缩行换行:不换行 | 换行 | 反转换行   
  2. //新版本同混合版本   
  3. flex-wrap: nowrap[默认] | wrap | wrap-reverse   
  4. //旧版本,没有浏览器支持box-lines属性,所以在旧版本中无法实现伸缩项目换行显示   
  5. box-lines: single[默认] | multiple | N/A  

[注意]此时,CSS允许使用overflow属性来处理溢出内容的显示方式   

[注意]伸缩项目的排列顺序同样与direction和wrinting-mode有关系

【3】伸缩流:伸缩流方向与伸缩行换行的缩写

  1. //伸缩流: 伸缩流方向 | 伸缩行换行   
  2. //新版本同混合版本   
  3. flex-flow: <flex-direction> | <flex-wrap>    
  4. [默认值] flex-flow: row nowrap  
  5. //旧版本无对应属性  

【4】主轴对齐:用来设置伸缩容器当前行伸缩项目在主轴方向的对齐方式,指定如何在伸缩项目之间分布伸缩容器额外空间

  当一行上的所伸缩项目不能伸缩或可伸缩已达到最大长度时,这一属性才会对伸缩容器额外空间进行分配。当伸缩项目溢出某一行时,这一属性也会在项目的对齐上施加一些控制

  1. //主轴对齐方式: 左对齐 | 居中对齐 | 右对齐 | 两端对齐 | 扩散对齐   
  2. //新版本   
  3. justify-content: flex-start[默认] | center | flex-pack | flex-end |&

您可能想查找下面的文章:

  • css小技巧
  • 各大网站CSS初始化代码
  • css权重问题
  • CSS实现鼠标上移图标旋转效果
  • 使用CSS3制作一个简单的进度条(demo)
  • 用纯CSS实现饼状Loading等待图效果
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果

相关文章

  • 2017-08-06CSS的background属性的缩写顺序介绍
  • 2017-08-06CSS 在IE6, IE7 和IE8中的差别
  • 2017-08-06小议Data URI scheme及其在CSS中的相关使用
  • 2017-08-06关于几个常见的css字体设定问题探讨
  • 2017-08-06轻松掌握CSS3中的字体大小单位rem的使用方法
  • 2017-08-06使用简单的CSS3属性实现炫酷读者墙效果
  • 2017-08-06inline-block带来的元素间距问题解决
  • 2017-08-06CSS 日期垂直排列的两种技巧
  • 2017-08-06详解CSS3中@media的实际使用
  • 2017-08-06原生js方法document.getElementsByClassName在ie8及其以下的兼容性问题

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • CSS隐藏元素五种方法
    • CSS3 Columns分列式布局方法简介
    • css 的border属性改变hr颜色小示例
    • CSS 制作漂亮的网页表单
    • CSS中margin边界叠加问题及解决方案
    • CSS 选择符的用法和实例
    • 页面内嵌样式表中使用url(), 出现页面多次载入问题解决
    • 跨浏览器的inline-block声明上承诺了很多提供的却很少
    • 用CSS制作三角形和按钮的简单实例
    • CSS 网站性能优化笔记

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有