记录实现水平垂直居中的5种方法

记录块级元素实现水平垂直居中的方法,效果如图。

html 复制代码
<div class="parent">
  <div class="child">居中元素</div>
</div>


<style>
.parent {
  position: relative;
  width: 600px;
  height: 300px;
  background-color: #679389;
}
.child {
  width: 300px;
  height: 120px;
  background-color: #d8a7a0;
  text-align: center;
  line-height: 120px;
}
</style>

方法1: flex布局。给parent设置center_1。

css 复制代码
.center_1 {
  display: flex;
  justify-content: center;
  align-items: center;
}

方法2: grid布局。设置一个3x3的网格,将子元素放在中间个字中。给parent设置center_2 ,给child设置center_2--child

css 复制代码
.center_2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
}
.center_2--child {
  grid-row-start: 2;
  grid-column-start: 2;
}

方法3: absolute+margin矫正偏移。给child设置center_3,此时margin矫正的位置分别是宽高的一半,因此需要知道子元素的宽高。

css 复制代码
.center_3 {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -60px;
  margin-left: -150px;
}

方法4: absolute+transfom矫正偏移。给child设置center_3。

css 复制代码
.center_4 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

方法5: display: table-cell。给parent 设置center_5,此时如果子元素为块级元素,text-align不会生效,可以给子元素child设置display: inline-block。

css 复制代码
.center_5 {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
.center_5--child {
  display: inline-block;
}
相关推荐
lantian17 分钟前
TypeScript 三斜线指令完全指南:从入门到理解为什么不再需要它
前端·javascript·vue.js
鹏多多18 分钟前
锐评CSDN最近上线的AI数字营销:烂完之前最后再捞一笔
前端·后端·程序员
先吃饱再说21 分钟前
从 WeUI 按钮组件学 BEM 命名规范:让 CSS 不再难维护
前端·代码规范
槑有老呆21 分钟前
从前端 HTTP 请求到 LLM 接口调用:一篇文章带你彻底搞懂
前端
陈_杨25 分钟前
鸿蒙APP开发-带你走进旧物集的时间线与收藏管理
前端·javascript
拂尘子38 分钟前
前端屎山代码救星:这个 MCP 把 7000 行页面压成 60 行骨架,Token 直接省掉 90%+
前端·ai编程·mcp
小雨下雨的雨42 分钟前
月相分析工具鸿蒙PC Electron框架技术实现详解
前端·javascript·华为·electron
布依前端1 小时前
基于 Vue 3 的 Tiptap 富文本编辑器实践:tiptap-editor-vue3 项目介绍
前端·javascript·vue.js
阿狸猿1 小时前
论负载均衡技术在 Web 系统中的应用
运维·前端·负载均衡
橘猫走江湖1 小时前
Cursor Vibe Coding 开发指南
前端