【纯干货分享】CSS3 中的居中对齐技巧

简介: 【纯干货分享】CSS3 中的居中对齐技巧

前端开发中,实现元素的居中对齐是一个常见的需求。CSS3 提供了多种灵活的技巧,可以实现水平和垂直方向的居中对齐。

1. 水平居中对齐

1.1 text-align: center;

对于行内元素,可以通过设置父元素的 text-align 属性为 center 来实现水平居中对齐。

.parent {
  text-align: center;
}
 
.child {
  display: inline-block;
}

1.2 margin: auto;

对于块级元素,可以使用 margin: auto; 来实现水平居中对齐。这需要父元素设置宽度,并且子元素需要是块级元素。

.parent {
  width: 50%;
  margin: auto;
}
 
.child {
  display: block;
}

1.3 flexbox

使用 Flexbox 布局可以更轻松地实现水平居中对齐。

.parent {
  display: flex;
  justify-content: center;
}
 
.child {
  /* 没有特殊要求 */
}

2. 垂直居中对齐

2.1 line-height

对于单行文本,可以使用 line-height 属性实现垂直居中对齐。

.parent {
  height: 100px;
  line-height: 100px;
}
 
.child {
  display: inline-block;
}

2.2 flexbox

Flexbox 布局同样适用于垂直居中对齐。

.parent {
  display: flex;
  align-items: center;
  justify-content: center;
}
 
.child {
  /* 没有特殊要求 */
}

2.3 positiontransform

使用 position: absolute;transform 属性可以实现相对于父元素的垂直居中对齐。

.parent {
  position: relative;
  height: 200px;
}
 
.child {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

3. 水平和垂直居中对齐

3.1 flexbox

结合使用 Flexbox 布局可以轻松实现水平和垂直方向的居中对齐。

.parent {
  display: flex;
  align-items: center;
  justify-content: center;
}
 
.child {
  /* 没有特殊要求 */
}

3.2 positiontransform

同样,使用 positiontransform 属性可以实现水平和垂直方向的居中对齐。

.parent {
  position: relative;
  height: 200px;
}
 
.child {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
相关文章
|
5月前
|
前端开发
CSS水平居中与垂直居中的方法
CSS水平居中与垂直居中的方法
|
5月前
|
前端开发 小程序
CSS元素居中大全
CSS元素居中大全
|
3月前
|
前端开发 C++ 容器
CSS【详解】居中对齐 (水平居中 vs 垂直居中)
CSS【详解】居中对齐 (水平居中 vs 垂直居中)
39 0
|
5月前
|
前端开发
CSS 字体对齐
CSS 字体对齐
58 0
【css3】盒子居中的8中方法
【css3】盒子居中的8中方法
68 0
|
前端开发
解决css中子元素靠边对齐问题
解决css中子元素靠边对齐问题
|
前端开发 Android开发
css图片剪裁居中
列表显示图片的时候,一般设置图片宽度自适应,那么高度就会根据图片本身的宽高比等比缩放,那么问题来了,多张图片的宽高比可能本身并不相同,那么造成图片宽度一样,高度不一样,显示不好看,不协调。如下图,图1和图2.怎么才能实现图片居中剪切,避免图片变形呢,css属性object-fit就可以实现
133 0
css图片剪裁居中
|
前端开发
CSS的垂直居中和水平居中总结
CSS的垂直居中和水平居中总结
131 0
|
前端开发
CSS:一行上不同大小的文字上下垂直居中对齐
CSS:一行上不同大小的文字上下垂直居中对齐
342 0
CSS:一行上不同大小的文字上下垂直居中对齐
|
Web App开发 前端开发 UED
CSS3居中
CSS3居中
133 0