css 布局

2019-01-31  本文已影响0人  前端伊始

预备知识: 定位,尺寸,浮动布局,flex布局,移动端时代

一. 定位:position: relative/absolute/fixed/static/inherit/sticky

偏移量属性: top, left, right, bottom; 我们知道这些属性不会对static的元素起到作用。这也就是其最大区别于margin属性的地方,margin主要针对盒模型设置外边距。

二.尺寸: px, %, rem, em

三.浮动: float: left/right

  1. 浮动最开始不是用来布局,主要是用来做文字环绕的。
  2. 清楚浮动的两种方法:
    overflow: 将父元素的overflow,设置成hidden。
    after伪类:对子元素的after伪类进行设置。

四.flex布局

知乎image.png

flex布局的重要概念如下:

.parent {
    display: flex | inline-flex;   //容器被设置为flex布局后,其子元素的 float、clear、vertical-align 的属性将会失效。
}
.parent {
flex-direction:  row | row-reverse | column | column-reverse;//默认为row,表示水平从左向右排列
flex-wrap: nowrap | wrap | wrap-reverse;  //默认为nowrap,表示即当主轴尺寸固定时,当空间不足时,项目尺寸会随之调整而并不会挤到下一行。
flex-flow: 老老实实用上面分开的写法吧,不用记这个了
justify-content: flex-start | flex-end | center | space-between | space-around;//定义了项目在主轴的对齐方式。
align-items:flex-start | flex-end | center | baseline | stretch;// 定义了项目在交叉轴上的对齐方式
align-content:flex-start | flex-end | center | space-between | space-around | stretch;
}

平时经常用到两端布局,这时候第一个想到的就是: justify-content: space-between

.item {
order: <integer>; //定义项目的排列顺序,数值越小,排列越靠前,默认值为 0
flex-basis: <length> | auto; //定义了在分配多余空间之前,项目占据的主轴空间,浏览器根据这个属性,计算主轴是否有多余空间。当主轴为水平方向的时候,当设置了 flex-basis,项目的宽度设置值会失效,flex-basis 需要跟 flex-grow 和 flex-shrink 配合使用才能发挥效果。
flex-grow: <number>; //定义项目的放大比例
flex-shrink: <number>; //定义项目的缩小比例
flex:  none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ];//上述三种属性的简写
align-self: auto | flex-start | flex-end | center | baseline | stretch; //允许单个项目有与其他项目不一样的对齐方式
}
上一篇 下一篇

猜你喜欢

热点阅读