CSS居中完整篇
水平居中
inline
或inline-*
元素此类元素需要水平居中,则父级元素必须是块级元素(
block level
),且父级元素上需要这样设置样式:1
2
3.parent {
text-align: center;
}块级元素
块级元素水平居中,需要设置
margin-left
和margin-right
为auto
,且需要显示设置宽度,不然就占满整行,就无所谓水平居中了。1
2
3
4.block {
width: 300px;
margin: 0 auto;
}
同一行多个块级元素
如果是在同一行里需要居中多个块级元素,可以尝试下面的两种方法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16/* 方法一 */
.parent {
text-align: center;
}
.parent div {
display: inline-block;
}
/* 方法二 */
.parent {
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
}
垂直居中
垂直居中在 CSS
中比较不好处理。
单行文本
通过设置上下内间距一致达到垂直居中的效果:
1
2
3
4.single-line {
padding-top: 10px;
padding-bottom: 10px;
}通过设置
height
和line-height
一致达到垂直居中:1
2
3
4.single-line {
height: 100px;
line-height: 100px;
}多行文本
通过使用表格来垂直居中,但是这种方法显得很累赘:
1
2
3
4
5
6
7
8
9<table>
<tbody>
<tr>
<td>
通过表格使得多行文本自动垂直居中通过表格使得多行文本自动垂直居中通过表格使得多行文本自动垂直居中
</td>
</tr>
</tbody>
</table>通过设置
vertical-align
属性和将元素设置为table-cell
,且父元素要设置为table
元素,这个和上面那种原理其实是一样的:1
2
3
4
5
6
7.parent {
display: table;
}
.parent div {
display: table-cell;
vertical-align: middle;
}通过伸缩盒来垂直居中:
1
2
3
4
5
6
7.flex-vertically {
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
display: -webkit-flex;
display: flex;
}块级元素垂直居中
知道块元素的高度,那么使用绝对定位和负的
margin
即可实现垂直居中:1
2
3
4
5
6
7
8
9.parent {
position: relative;
}
.parent div {
position: absolute;
top: 50%;
height: 50px;
margin-top: -25px;
}块级元素高度是可变的,这个时候就需要用
transform
的 Y 轴平移来实现了:1
2
3
4
5
6
7
8.parent {
position: relative;
}
.parent div {
position: absolute;
top: 50%;
transform: translateY(-50%);
}也可以使用
flexbox
:1
2
3
4
5.parent {
display: flexbox;
justify-content: center;
flex-direction: column;
}如果对于块级元素高度不是固定的,且不由内容决定,那么还可以这么设置:
1
2
3
4
5
6
7
8.parent {
position: relative;
}
.parent div {
position: absolute;
top: 30%;
bottom: 30%;
}
水平垂直居中
水平垂直居中就是把上面介绍的方法相结合就可以了。
知道宽高的盒子
1
2
3
4
5
6
7
8
9
10
11
12.parent {
position: realtive;
}
.parent div {
width: 300px;
height: 300px;
posotion: absoltue;
left: 50%;
top: 50%;
margin-left: -150px;
margin-top: -150px;
}不知道宽高的盒子
1
2
3
4
5
6
7
8
9.parent {
position: realtive;
}
.parent div {
posotion: absoltue;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
}使用
flexbox
1
2
3
4
5.parent {
display: flex;
justify-content: center;
align-items: center;
}