水平居中的几种方法(总结)

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%);
}
相关推荐
大橙子额40 分钟前
【解决报错】Cannot assign to read only property ‘exports‘ of object ‘#<Object>‘
前端·javascript·vue.js
RFCEO40 分钟前
前端编程 课程十六、:CSS 盒子模型
css·前端基础课程·css盒子模型·css盒子模型的组成·精准控制元素的大小和位置·css布局的基石·内边距(padding)
爱喝白开水a2 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
董世昌412 小时前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
吃杠碰小鸡3 小时前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone3 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09014 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农4 小时前
Vue 2.3
前端·javascript·vue.js
夜郎king4 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落
夏幻灵5 小时前
HTML5里最常用的十大标签
前端·html·html5