css3弹性盒子布局

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

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

display:flex和display:box都可用于弹性布局,不同的是display:box是2009年的命名,已经过时,用的时候需要加上前缀;display:flex是2012年之后的命名。在实际的测试中display:flex不能完全的替代display:box。display:flex的浏览器兼容性比较麻烦。

1.关于display:flex

对于PC端,一般chrome和火狐都能很好地支持。ie不支持,显示的是顺序排列下来的宽度100%的模块。

对于移动端:

(1)上述代码iOS的原生safari浏览器是支持的;UC浏览器支持的很好;微信浏览器不支持

(2)安卓的原生浏览器不支持,能够正常显示模块,文档流依次排列;UC浏览器不支持,显示为空白;微信浏览器不支持

2.关于display:box

PC端:chrome和火狐都能很好地支持。ie不支持,显示的是顺序排列下来的宽度100%的模块。

移动端:

(1)上述代码iOS的原生safari浏览器是支持的;UC浏览器支持的很好

(2)安卓的原生浏览器支持;UC浏览器不支持,显示为空白

总的来说,不考虑IE浏览器的话,PC端上使用哪个都可以,一般使用display:flex;移动端的安卓的UC只支持display:box,iOS的UCdisplay:box和display:flex两个都支持。

兼容浏览器的写法

display: -webkit-box; /* Chrome 4+, Safari 3.1, iOS Safari 3.2+ */

display: -moz-box; /* Firefox 17- */

display: -webkit-flex; /* Chrome 21+, Safari 6.1+, iOS Safari 7+, Opera 15/16 */

display: -moz-flex; /* Firefox 18+ */

display: -ms-flexbox; /* IE 10 */

display: flex; /* Chrome 29+, Firefox 22+, IE 11+, Opera 12.1/17/18, Android 4.4+ */

先介绍一下display:box 的写法

1.box-align:start/end/center/baseline/stretch

在父级设置,子代的垂直对齐方式。

start

对于正常方向的框,每个子元素的上边缘沿着框的顶边放置。

对于反方向的框,每个子元素的下边缘沿着框的底边放置。

end

对于正常方向的框,每个子元素的下边缘沿着框的底边放置。

对于反方向的框,每个子元素的上边缘沿着框的顶边放置。

center

均等地分割多余的空间,一半位于子元素之上,另一半位于子元素之下。

baseline

如果 box-orient 是inline-axis或horizontal,所有子元素均与其基线对齐。

stretch

拉伸子元素以填充包含块,与父级设置的高度一致。子代height无效。

-webkit-box-align:center;

box-align:center;

2.box-pack:start/end/center/justify

在父级设置,子代的水平对齐方式。

start

对于正常方向的框,首个子元素的左边缘被放在左侧(最后的子元素后是所有剩余的空间)

对于相反方向的框,最后子元素的右边缘被放在右侧(首个子元素前是所有剩余的空间)

end

对于正常方向的框,最后子元素的右边缘被放在右侧(首个子元素前是所有剩余的空间)。

对于相反方向的框,首个子元素的左边缘被放在左侧(最后子元素后是所有剩余的空间)。

center

均等地分割多余空间,其中一半空间被置于首个子元素前,另一半被置于最后一个子元素后

justify

在每个子元素之间分割多余的空间(首个子元素前和最后一个子元素后没有多余的空间)。

-webkit-box-pack:center;

box-pack:center;

3.box-orient:horizontal|vertical|inline-axis|block-axis|inherit

horizontal

在水平行中从左向右排列子元素

vertical

从上向下垂直排列子元素

inline-axis

沿着行内轴来排列子元素(映射为 horizontal)

block-axis

沿着块轴来排列子元素(映射为 vertical)

inherit

应该从父元素继承 box-orient 属性的值。

-webkit-box-orient:vertical;

box-orient:vertical;

4.box-direction: normal|reverse|inherit;

normal

以默认方向显示子元素

reverse

以反方向显示子元素

inherit

应该从子元素继承 box-direction 属性的值

5.box-flex:number;

1)占父级元素宽度的number份

2)若子元素设置固定宽度,则该子元素应用固定宽度,其他未设置固定宽度的字元素将余下的父级宽度(父级-已设置固定宽度的子代元素的总宽度按 number占份数

3)若子元素有margin值,则按余下(父级宽度-子代固定总宽度-总margin值)宽度占number份

下面介绍一下display 属性的值为 flex 或 inline-flex的写法

常用属性有

flex-direction

指定弹性容器中子元素排列方式

flex-wrap

设置弹性盒子的子元素超出父容器时是否换行

flex-flow

flex-direction 和 flex-wrap 的简写

align-items

设置弹性盒子元素在侧轴(纵轴)方向上的对齐方式

align-content

修改 flex-wrap 属性的行为,类似 align-items, 但不是设置子元素对齐,而是设置行对齐

justify-content

设置弹性盒子元素在主轴(横轴)方向上的对齐方式

1. flex-direction 属性

flex-direction: row | row-reverse | column | column-reverse;

row

默认值。元素将水平显示,正如一个行一样。

row-reverse

与 row 相同,但是以相反的顺序。

column

元素将垂直显示,正如一个列一样。

column-reverse

与 column 相同,但是以相反的顺序。

2. flex-wrap 属性

flex-wrap: nowrap | wrap | wrap-reverse;

nowrap

默认值。规定元素不拆行或不拆列。

wrap

规定元素在必要的时候拆行或拆列。

wrap-reverse

规定元素在必要的时候拆行或拆列,但是以相反的顺序。

3. flex-flow 属性

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

flex-flow:

4. align-items属性

align-items 属性定义flex子项在flex容器的当前行的侧轴(纵轴)方向上的对齐方式。

stretch

默认值。项目被拉伸以适应容器。

center

项目位于容器的中心。

flex-start

项目位于容器的开头。

flex-end

项目位于容器的结尾。

baseline

项目位于容器的基线上。

5. justify-content属性

justify-content 用于设置或检索弹性盒子元素在主轴(横轴)方向上的对齐方式。

flex-start

默认值。项目位于容器的开头。

flex-end

项目位于容器的结尾。

center

项目位于容器的中心。

space-between

项目位于各行之间留有空白的容器内。

space-around

项目位于各行之前、之间、之后都留有空白的容器内。

弹性子元素属性

order

设置弹性盒子的子元素排列顺序。

flex-grow

设置或检索弹性盒子元素的扩展比率。

flex-shrink

指定了 flex 元素的收缩规则。flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。

flex-basis

用于设置或检索弹性盒伸缩基准值。

flex

设置弹性盒子的子元素如何分配空间。

align-self

在弹性子元素上使用。覆盖容器的 align-items 属性。

1. order属性

order: ;

用整数值来定义排列顺序,数值小的排在前面。可以为负值,默认为0。

2. flex-grow属性

flex-grow: ;

integer:一个数字,规定项目将相对于其他灵活的项目进行扩展的量。默认值是 0。

3. flex-shrink属性

flex-shrink: ;

integer:一个数字,规定项目将相对于其他灵活的项目进行收缩的量。默认值是 1。

4. flex-basis属性

flex-basis: | auto;

integer:一个长度单位或者一个百分比,规定元素的初始长度。

auto:默认值。长度等于元素的长度。如果该项目未指定长度,则长度将根据内容决定。

5. flex属性

flex 属性用于设置或检索弹性盒模型对象的子元素如何分配空间。

flex 属性是 flex-grow、flex-shrink 和 flex-basis 属性的简写属性

flex: flex-grow flex-shrink flex-basis | auto | initial | inherit;

flex-grow

一个数字,规定项目将相对于其他元素进行扩展的量。

flex-shrink

一个数字,规定项目将相对于其他元素进行收缩的量。

flex-basis

项目的长度。合法值:“auto”、“inherit” 或一个后跟 “%”、“px”、“em” 或任何其他长度单位的数字。

auto

与 1 1 auto 相同。

none

与 0 0 auto 相同。

initial

设置该属性为它的默认值,即为 0 1 auto。

inherit

从父元素继承该属性。

6. align-self属性

align-self: auto | stretch | center | flex-start | flex-end | baseline | initial | inherit;

auto

默认值。元素继承了它的父容器的 align-items 属性。如果没有父容器则为 “stretch”。

stretch

元素被拉伸以适应容器。

center

元素位于容器的中心。

flex-start

元素位于容器的开头。

flex-end

元素位于容器的结尾。

baseline

元素位于容器的基线上。

initial

设置该属性为它的默认值。

inherit

从父元素继承该属性。

html弹性盒子垂直排列,css3弹性盒子布局相关推荐

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

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

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

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

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

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

  4. CSS3弹性盒子布局

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

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

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

  6. CSS3 弹性盒子(Flex Box)

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

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

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

  8. CSS3弹性盒子Flex

    CSS3弹性盒子Flex 基础知识和术语 原文链接:https://css-tricks.com/snippets/css/a-guide-to-flexbox/ 父级(flex容器)的属性 #显示 ...

  9. CSS3 弹性盒子模型

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

最新文章

  1. [svc]arp协议的细枝末节
  2. 祭旗篇---关于提高技术团队技术氛围的一些尝试
  3. hive的变量传递设置
  4. 一起学nRF51xx 20 -  移植SDK蓝牙例程
  5. 获取http请求响应头
  6. VTK:可视化之ColorAnActor
  7. python代码学习-数据处理图片加遮挡、噪声、模糊
  8. STM32F1笔记(七)WWDG窗口看门狗
  9. Windows系统环境下Solr之Java实战(三)使用solrJ管理索引库
  10. 亿能bms上位机_BMS上位机 - 源码下载|Windows编程|通讯编程|源代码 - 源码中国
  11. fme坐标转换器_利用FME做坐标转换
  12. allgro pcb铜皮编辑_干货技巧-Allegro如何设置整体铜皮连接或设置单个管脚连接方式...
  13. windows11 安全中心点击进去内容空白解决方法
  14. 解决Number of partitions scanned (=2001) on table ‘tablexx‘ exceeds limit (=2000)
  15. 论文笔记——使用信息熵对复杂网络中节点进行影响力排名
  16. Tomat连接MySQL示例
  17. android.view.WindowLeaked的解决办法 has leaked window android.widget.PopupWindow$PopupDecorView
  18. JDK 8 - computeIfAbsent,computeIfPresent,compute
  19. linux环境下查看进程,Linux下查看进程(程序)启动时的环境变量
  20. 【Python编程:从入门到实践】第四章:操作列表

热门文章

  1. 阿里巴巴集团副总裁陈丽娟对话VMware全球副总裁原欣:助力企业数字化转型
  2. 计算机专业考研390分是什么水平,考研初试390分被淘汰,复试到底发生了什么?...
  3. 回溯法求解0-1背包问题
  4. stc c语言编程,谁有STC 的 EEPROM C程序
  5. Ubuntu20.04用gparted软件给/目录 or /home目录扩容 or 压缩
  6. 计算机系统结构第二版习题答案,计算机系统结构课后习题答案(第2版).docx
  7. maven打包可执行的jar包-包含依赖jar
  8. 第一百篇,真实可重现,详细实现昨日剩下的功能
  9. 加密货币、区块链不断贴近生活,阿里、腾讯、脸书等大厂们在做什么?
  10. excel时间戳转换为时间格式