CSS Flex弹性布局:容器和项目6个属性(附效果图)

2018-12-1414:35:54网页制作Comments4,008 views1字数 1999阅读模式

Flex是Flexible Box 的缩写,意为"弹性布局",是CSS3的一种布局模式。通过Flex布局,可以很优雅地解决很多CSS布局的问题。下面会分别介绍容器的6个属性和项目的6个属性。每个属性会附上效果图,具体实现代码会以github路径形式更新于此。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

1.浏览器支持情况

可以点击查看各浏览器的兼容情况文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

2.容器的属性

注意,设为 Flex 布局以后,子元素的float、clear和vertical-align属性将失效。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

容器的属性有6个,分别是:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-direction文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-wrap文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-flow文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

justify-content文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

align-items文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

align-content文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

(1)flex-direcion属性:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:控制主轴的方向文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-direction: row | row-reverse | column | column-reverse;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:row文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

(2)flex-wrap属性:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:默认情况下,项目都排在一条线(又称"轴线")上。flex-wrap属性定义,如果一条轴线排不下,如何换行。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-wrap: nowrap | wrap | wrap-reverse;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:nowrap文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

(3)flex-flow属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:该属性是flex-direction属性和flex-wrap属性的简写形式文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:row nowrap文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

(4)justify-content属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:定义项目在主轴上的对齐方式文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

justify-content: flex-start | flex-end | center | space-between | space-around;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:flex-start文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

(5)align-items属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:定义项目在交叉轴上如何对齐。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

align-items: flex-start | flex-end | center | baseline | stretch文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:flex-start文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

注意:如果align-items为stretch,想看到每个flex-item铺满整个交叉轴的话,需要设置所有的flex-item的高度:height:auto,否则达不到效果。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

(6)align-content属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

align-content: flex-start | flex-end | center | space-between | space-around | stretch;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:stretch文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-start:与交叉轴的起点对齐。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-end:与交叉轴的终点对齐。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

center:与交叉轴的中点对齐。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

stretch:轴线占满整个交叉轴。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

3.项目的属性

项目的属性有6个,分别是:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

order文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-grow文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-shrink文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex-basis文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

align-self文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

(1)order属性:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:定义项目的排列顺序,数值越小,排列越靠前。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:0文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

(2)flex-grow属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:如果存在剩余空间,项目放大的比例。相当于是各个项目根据这个比例,来分配剩余空间。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:0(不放大)文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

(3)flex-shrink属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:flex-shrink:如果存在空间不足,项目的“缩小比例”。0表示当空间不足时,不缩小。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:1文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

负值对该属性无效文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

(4)flex-basis属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:定义项目在主轴方向上占据空间大小的初值。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:auto(项目本来的大小)文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

(5)flex属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:是flex-grow、flex-shrink、flex-basis属性的缩写形式;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex: none | [<'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

注:几种常见缩写形式;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex: auto; === flex: 1 1 auto;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex: none; === flex: 0 0 auto;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex: initial; === flex: 0 1 auto;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex: ; === flex: 1 auto;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

flex: 1; === flex: 1 1 auto;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

(6)align-self属性文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作用:属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

align-self: auto | flex-start | flex-end | center | baseline | stretch;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

默认值:auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

CSS Flex弹性布局:容器和项目6个属性(附效果图)

4.小结

本文分别介绍了容器的6个属性和flex-item项目的6个属性。建议跟着demo整体做一遍,有助于加深理解。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

作者:腾讯云加社区
来源:掘金文章源自菜鸟学院-https://www.cainiaoxueyuan.com/zhizuo/8646.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/zhizuo/8646.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定