1.text-align:center(内联或者内联块元素)
适用情况 :父元素是块级元素,子元素是内联或内联块级元素(如文本、图片、inline-block
)。
css
.parent {
text-align: center;
}
2.margin: 0 auto (块级元素,需要设定宽度)
适用情况:子元素是块级元素,并且元素有固定宽度。
css
.child {
width: 200px; /* 必须指定宽度 */
margin: 0 auto;
}
3.flex的justify-content:center(适用于任何元素)
适用情况:适用于任何类型的元素。
css
.parent {
display: flex;
justify-content: center;
}
4.position:absolute 和 transform (绝对定位元素)
适用情况:子元素是绝对定位元素,父元素需相对定位。
css
.parent {
position: relative;
}
.child {
position: absolute;
left: 50%;
transform: translateX(-50%);
}
5.grid的justify-content:center(适用于任何元素)
适用情况:适用于任何类型的元素。
css
.parent {
display: grid;
justify-content: center;
}
6.display:table 和margin: 0 auto
适用情况:子元素是块级元素,但父元素的宽度不确定或子元素无明确宽度。
css
.parent {
display: table;
margin: 0 auto;
}
7.float 和 position:relative
适用情况:需要兼容老旧浏览器。
css
.parent {
position: relative;
}
.child {
float: left;
left: 50%;
position: relative;
transform: translateX(-50%);
}
8.inline-block和 text-align:center
适用情况:适用于多个块级子元素的水平居中。
css
.parent {
text-align: center;
}
.child {
display: inline-block;
}
9.inline-flex和justify-content:center
适用情况:用于内联块级元素的水平居中,子元素是行内的 flex 项目。
css
.parent {
display: inline-flex;
justify-content: center;
}
10.table-cell和text-align:center
适用情况 :在父元素为 table-cell
时,可以通过 text-align
进行居中。
css
.parent {
display: table-cell;
text-align: center;
}
11.just-self:center(Grid布局)
适用情况:适用于 Grid 布局中的单个网格项目水平居中。
css
.parent {
display: grid;
}
.child {
justify-self: center;
}
12.text-indent和white-space:nowrap(单文本居中)
适用情况:适用于水平居中文本,尤其是在单行文本的场景下。
css
.parent {
text-align: justify;
white-space: nowrap;
text-indent: 50%;
transform: translateX(-50%);
}