弹性布局
Posted boring333
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了弹性布局相关的知识,希望对你有一定的参考价值。
弹性布局
一个盒子,如果将其display属性设置为flex,该盒子变为弹性盒(弹性容器),该盒子的
所有子元素,自动变为弹性项目。弹性盒本身按照自身的定位体系排列,弹性布局影响的仅
仅是弹性盒中的弹性项目
属性:
flex-direction:更改主轴方向
l row 行 默认值
l row-reverse 反向 主轴从右向左
l column 列 按主轴从上往下排列
l column-reverse 按主轴从下往上
justify-content :更改主轴对其方式
l flex-start 默认值 主轴起点一次排列
l flex-end 主轴终点对齐
l center 主轴中线对齐
l space-between 左右项目靠边,中间平均分布
l space-around 所有项目平均分布
align-items: 更改侧轴对齐方式
l stretch 默认值 拉伸
l flex-start 侧轴起点对齐
l flex-end 侧轴终点对齐
l flex-center 侧轴中线对齐
flex-wrap
l wrap(换行)
l nowrap(不换行)
align-content
规则:弹性项目宽度自动时,表示适应内容的宽度和高度。margin为自动时,会吸收
弹性容器的剩余空间。
项目属性 :
l order 更改弹性项目的排列顺序,顺序为从小到大进行排列
l flex-shrink 更改弹性项目的压缩比例
1 默认
0 不压缩
flex-grow 更改弹性项目的增长比例
0 默认 不增长
flex-basis 弹性项目在压缩或增长前的基础宽度,若不设置,默认值为auto,表示
与width属性值相同
速写 flex:grow shrink basis;同时设置增长、压缩、基础值
水平居中(包含块中居中)
1. 定宽,左右margin为auto。(常规流块盒、弹性项目[不用定宽])
2. 弹性盒设置justify-content: center,让弹性项目在主轴上居中。(普遍适应)
3. 父元素设置text-align: center,让其内部的行盒、块盒居中。
4. 绝对定位元素,left:0? right:0? 定宽;左右margin: auto。
5. margin-left:50%? transform:translateX(-50%)。[margin,padding相对于包含块宽度的百分
比] 【终极方案】
垂直居中
1. 单行文本垂直居中,设置父元素的line-height为包含块高度。
2. 弹性盒设置align-items:center,让弹性项目在侧轴上居中。
3. 绝对定位元素,top:0;bottom:0;定高;上下margin:auto。
4. 绝对定位元素,top:50%;transform:translateY(-50%)。【终极方
案】
绝对定位元素水平垂直居中
left:50%;top:50%;transform:translate(-50%,-50%);
行盒和块盒的区别
1. 行盒不可设置宽高,垂直方向上所有尺寸不占用空间,但水平方向上的margin、border、
padding可以。块盒所有尺寸有效。
2. 行盒会在合适位置被截断,而块盒不行。
3. 行盒只有常规流(浮动和绝对定位会强行将之转换为块盒),排列时,与其他行盒首尾相
接。块盒有多种定位体系,每种定位体系按照自身规则排列。
4. 行盒之间和行盒内部会空白折叠。块盒不会。
伪类选择器:
1. :hover,鼠标悬浮时的效果
2. :active,a/button元素激活(按钮)时的效果
3. :link,a元素未访问过的样式
4. :visited,a元素访问过的样式
5. :checked,单元或多选被选中的样式
6. :focus,表单元素聚焦的样式
7. :firstchild,第一个子元素
8. :lastchild,最后一个子元素
9. :nthchild(2),第二个子元素;
10. :nthchild(2n)/:nthchild(even),第偶数个子元素;
11. :nthchild(odd),第奇数个子元素
伪元素选择器
1. ::before,在内部生成一个子元素,作为第一个子元素,然后选中它
2. ::after,在内部生成一子元素,作为最后一个子元素,然后选中它
3. :selection,选中被框选的文字
后缀\0:IE5~IE7
前缀*:IE5~IE7
前缀_:IE5~IE6
设置color属性,让非IE浏览器为绿色,IE5~IE6为红色,IE7为棕色,IE8~IE11为黑色
color:green;
color\0:black;
*color:brown;
_color:red;
height的百分比相对于包含块的高度,其有效的前提条件是:包含块的高度是可计算的
给html设置100%,是视口的高度。
CSS框架
bootstrap
理念:移动端优先,响应式,栅格系统(960布局)
960布局:主区域宽度为960像素,将区域内部划分为12列,每列之间间隔10像素,每
列宽度60像素
以上是关于弹性布局的主要内容,如果未能解决你的问题,请参考以下文章