900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > CSS中flex的用法( 学习笔记 )

CSS中flex的用法( 学习笔记 )

时间:2021-06-02 10:32:30

相关推荐

CSS中flex的用法( 学习笔记 )

flex( 弹性盒、伸缩盒 )

flex 的介绍

flex是CSS中的又一种布局手段,它主要用来代替浮动来完成页面的布局flex可以使元素具有弹性,让元素可以随页面的大小的改变而改变

弹性容器

要使用弹性盒,必须先将一个元素设置为弹性容器我们通过 display 来设置弹性容器display:flex 设置为块级弹性容器(常用)deplay:inline-flex 设置为行内的弹性容器

弹性元素

弹性容器的直接子元素( 非后代 )是弹性元素(弹性项)弹性元素可以同时是弹性容器

弹性容器的属性

一、flex-direction

flex-direction 指定容器中弹性元素的排列方式可选值: row 默认值,弹性元素在容器中水平排列(从左向右) row-reverse弹性元素在容器中反向水平排列(从右向左)column 弹性元素纵向排列(从上向下)column-reverse 弹性元素纵向排列(从下向上) 主轴:弹性元素的排列方向称为主轴侧轴:与主轴垂直方向的称为侧轴

二、flex-grow(弹性元素的增长系数)

flex-grow 指定弹性元素的伸展的系数当父元素有多余空间的时候,子元素如何伸展父元素的剩余空间,会按照比例进行分配例子:flex-grow: 1; 默认值0时不伸展

三、flex-shrink(弹性元素的缩减系数)

flex-shrink 指定弹性元素的收缩系数当父元素中的空间不足以容纳所有子元素时,对子元素进行收缩

四、flex-wrap

设置弹性元素是否在弹性容器里自动换行可选值: nowrap 默认值,元素不会自动换行wrap 元素沿着辅轴方向自动换行wrap-reverse 元素沿着辅轴反方向换行flex-flow:wrap 和 direction 的简写属性

五、justify-conten

分配主轴上的空白空间(主轴上的元素如何排列)可选值: flex-start 元素沿着主轴起边排列flex-end 元素沿着主轴终边排列center 元素居中排列space-around 空白分布到元素两侧space-between 空白均匀分布到元素间space-evenly 空白分布到元素的单侧 注意:有justify的代表元素在主轴上的排列

六、align-items

元素在辅轴上如何对齐元素与元素间的关系可选值: stretch 默认值,将元素的长度设置为相同的值flex-start 元素不会拉伸,沿着辅轴起边对齐flex-end 元素不会拉伸,沿着辅轴终边对齐center 居中对齐baseline 基线对齐

七、align- content

分配辅轴上的空白空间可选值: flex-start 元素沿着主轴起边排列flex-end 元素沿着主轴终边排列center 元素居中排列space-around 空白分布到元素两侧space-between 空白均匀分布到元素间space-evenly 空白分布到元素的单侧 注意:有align的代表元素在辅轴上的排列

八、align-self

用来覆盖弹性元素上的align-items

九、flex-basis

指定的是元素在主轴上的基础长度如果主轴是横向的 则 该值指定的就是元素的高度如果主轴是纵向的 则 该值指定的就是元素的宽度默认值是 auto ,表示参考元素自身的高度或宽度如果传递了一个具体的数值,则以该值为准

十、order

设置弹性元素的排列顺序例子:order: 1; 弹性元素排第一个

总结:

flex可以设置弹性元素所有的三个样式:flex 增长 缩减 基础;可选值: initial “flex: 0 1 auto;”auto “flex: 1 1 auto;”none "flex: 0 0 auto"弹性元素没有弹性

w3school导航栏实例:

<ul class="nav"><li><a href="#">HTML/CSS</a></li><li><a href="#">Browser Side</a></li><li><a href="#">Server Side</a></li><li><a href="#">Programming</a></li><li><a href="#">XML</a></li><li><a href="#">Web Building</a></li><li><a href="#">Reference</a></li></ul>

.nav{width: 1210px;height: 48px;line-height: 48px;background-color: #E8E7E3;margin: 50px auto;margin-top: 100px;list-style: none;display: flex;padding-left: 0;}.nav li{flex-grow: 1;}.nav a{display: block;color: #808080;text-decoration: none;font-size: 18px;text-align: center}.nav a:hover{color: #fff;background-color: #636363;}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。