弹性盒模型

  弹性盒子是css3的一种新布局模式,由容器(父元素)和项目(子元素)组成。

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

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

设置弹性盒子:display:flex或inline-flex; 区别:flex独占一行;inline-flex占据自己应该占据的位置,有点像inline-block,不支持margin:auto。

容器属性

 1.flex-direction  确定主轴和方向

  • row 默认,从左到右
  • row-reverse  从右到左
  • column 从上到下
  • column-reverse 从下到上

2.flex-wrap 规定项目是否换行

  • nowrap 默认,不换行
  • wrap 换行,交叉轴从上到下
  • wrap-reverse 换行,第一行在下,交叉轴从下到上

3.flex-flow 复合属性,flex-direction和flex-wrap组成的复合属性

  • row nowrap 默认,从左到右不换行

4.justify-content 项目在主轴上的对齐方式

  • flex-start 默认,主轴起点对齐
  • flex-end 主轴终点对齐
  • center 主轴居中对齐
  • space-between 主轴上项目两端对齐,项目之间间隙平分空白
  • space-around 主轴上的项目两侧间隔相等

5.align-content 多行项目在交叉抽(与主轴垂直)上的对齐方式,不要和align-items共存

  • stretch 默认,不设置项目高度的时候,占满平分整个交叉轴
  • flex-start 交叉轴起点对齐
  • flex-end 交叉轴终点对齐
  • center 交叉轴居中对齐
  • space-between 交叉轴上项目两端对齐,项目之间间隙平分空白
  • space-around 交叉轴上项目两侧间隔相等

6.align-items 单行项目在交叉轴上的对齐方式

  • stretch 默认,不设置高度(竖直时)或宽度(水平时)占满整个交叉轴
  • flex-start 交叉轴的起点对齐
  • flex-end 交叉轴的终点对齐
  • center 交叉轴的中间对齐
  • baseline 文字基线对齐

项目属性

  1.flex-grow 设置项目的扩大比例

  • 0 默认,不扩大
  • 1 项目扩大填满容器,值为1时占一份,值为2时占两份,不支持负值

2.flex-shrink 设置项目的收缩比例

  • 1 默认,当容器宽度不够时,项目等比例缩小
  • 0 不缩小
  • 2,3...n 值越大缩小得越多

3.flex-basis 设置项目初始长度

  • auto 默认,项目没有设置宽度的时候,默认内容撑开宽度
  • 0 不设置初始值
  • number 规定项目的初始长度

4.flex 复合写法flex:flex-grow flex-shrink flex-basis

  • auto 相当于1 1 auto
  • none 相当于0 0 auto
  • 1 相当于1 1 0
  • initial 相当于0 1 auto

5.align-self 单独控制交叉轴一个项目的对齐方式

  • auto 默认值,继承父容器的align-items
  • 其他属性值与align-items一样

6.order 规定项目在主轴上的排列顺序

  • 0 默认,根据项目先后排列
  • 整数,可为负值,数值越小排名越靠前

以上为个人理解,如有不当之处请指正!

弹性盒模型,flex布局的更多相关文章

  1. css 弹性盒模型Flex 布局

    参考文章:http://www.runoob.com/w3cnote/flex-grammar.html Flex 布局是什么:采用Flex布局的元素,称为Flex容器(flex container) ...

  2. 弹性盒模型 flex box

    弹性盒子模型 布局方案 传统的布局方案大多采用div+css+float+position+display来实现,但是随着css3中弹性盒子模型的推出,在前端布局方案中就又多出了一项彪悍的选项. 而因 ...

  3. CSS3弹性盒模型flexbox布局基础版

    原文链接:http://caibaojian.com/using-flexbox.html 最近看了社区上的一些关于flexbox的很多文章,感觉都没有我这篇文章实在,最重要的兼容性问题好多人都没有提 ...

  4. css3弹性盒模型flex快速入门与上手(align-content与align-items)

    接着上文css3弹性盒模型flex快速入门与上手1继续,上文还剩下两个父容器的属性align-items和align-content. 一.align-content:多行的副轴对齐方式 含义 多行的 ...

  5. CSS弹性盒模型flex在布局中的应用

    × 目录 [1]元素居中 [2]两端对齐 [3]底端对齐[4]输入框按钮[5]等分布局[6]自适应布局[7]悬挂布局[8]全屏布局 前面的话 前面已经详细介绍过flex弹性盒模型的基本语法和兼容写法, ...

  6. 深入理解CSS弹性盒模型flex

    × 目录 [1]版本更迭 [2]display [3]基本概念[4]伸缩容器[5]伸缩项目 前面的话 CSS3引入了一种新的布局模型——flex布局.flex是flexible box的缩写,一般称之 ...

  7. CSS弹性盒模型(flex box)

    本文介绍的是 CSS3 规范中引入的新布局模型:弹性盒模型(flex box).随着响应式用户界面的流行,Web 应用一般都要求适配不同的设备尺寸和浏览器分辨率. 浏览器支持: 弹性盒布局的容器(fl ...

  8. CSS弹性盒模型flex概念

    盒模型分为:标准w3c盒模型.IE盒模型.以及css中的伸缩盒模型. 先说CSS的伸缩盒模型:flex模型是CSS3引入的新的布局模型,是flexible box的缩写,一般称之为弹性盒模型.和CSS ...

  9. CSS3弹性盒模型flexbox布局

    属性介绍 display: flex | inline-flex; (适用于父类容器元素上) 定义一个flex容器,内联或者根据指定的值,来作用于下面的子类容器.· box:将对象作为弹性伸缩盒显示. ...

  10. css3之弹性盒模型(Flex Box)

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

随机推荐

  1. nginx 日志切割脚本

    #!/bin/shLOG_PATH=/home/test/nginx/logsNEW_LOG_PATH=/home/test/nginx/dayslogNGING_PID=$(cat /home/te ...

  2. Matplotlib 使用 - 《Python 数据科学手册》学习笔记

    一.引入 import matplotlib as mpl import matplotlib.pyplot as plt 二.配置 1.画图接口 Matplotlib 有两种画图接口: (1)一个是 ...

  3. JSTL 和 EL

    EL表达式   Expression Language 语法${作用域中的值} 使用EL表达式时,需要在page标签中写上isELIgnored="false",否则EL表达式不生 ...

  4. java中根据key获取resource下properties资源文件中对应的参数

    properties资源文件是放在resource目录下的: 新建工具类: package com.demo.utils; import java.io.InputStream; import jav ...

  5. 工欲善其事,必先利其器-Python编辑器选择(2)

    前言:工欲善其事.必先利其器 一款顺手的好的编辑器可以让程序员写代码更得心应手,效率也会更高,但是编辑器本身没有好坏,只有使用者使用起来是否顺手而已,这里简单给大家介绍几款常用的可以编辑Python的 ...

  6. python基础-字符串(6)

    一.引言 当打来浏览器登录某些网站的时候,需要输入密码,浏览器把密码传送到服务器后,服务器会对密码进行验证,其验证过程是把之前保存的密码与本次传递过去的密码进行对比,如果相等,那么就认为密码正确,否则 ...

  7. salesforce零基础学习(九十二)使用Ant Migration Tool 实现Metadata迁移

    我们在做项目时经常会使用changeset作为部署工具,但是某些场景使用changeset会比较难操作,比如当我们在sandbox将apex class更改名字想要部署到生产的org或者其他环境的or ...

  8. Database Management System 基础01:管理自己的任何事

    前言 系列文章:[传送门] 这Database Management System 系列准备也慢慢的写出来了.Database Management是我学习的一块,这块出的也许比较慢.比较忙吧,坚持每 ...

  9. leetcode — longest-valid-parentheses

    import java.util.Stack; /** * Source : https://oj.leetcode.com/problems/longest-valid-parentheses/ * ...

  10. 详解CSS的Flex布局

    本文由云+社区发表 Flex是Flexible Box 的缩写,意为"弹性布局",是CSS3的一种布局模式.通过Flex布局,可以很优雅地解决很多CSS布局的问题.下面会分别介绍容 ...