css 水平垂直居中
css 水平垂直居中方案总结 已知宽高未知宽高
水平垂直居中不管是在项目还是面试中都屡见不鲜,故而写篇博客小结一下。
本篇从父子元素宽高已知或未知的角度来分开叙述。
已知宽高
以下是DOM、样式表以及效果图。由于效果一致,下面将不再频繁列出。
html
<div class="parent">
<div class="child">child</div>
</div>
css
.parent {
height: 500px;
width: 500px;
background-color: coral;
}
.child {
height: 100px;
width: 100px;
background-color: lightseagreen;
}
效果图
1 负margin + 绝对定位
margin+绝对定位是css水平垂直居中里一种较为常见的方案
由于绝对定位的百分比是基于父元素来计算的,因此需要减去子元素宽高的一半,达到子元素和父元素中位线对齐的效果,从而实现居中
为什么使用负margin+px?负margin+百分比行不行?
当然不行。因为此处margin的百分比也是基于父元素计算的。
.parent{
position: relative;
}
.child{
position: absolute;
left: 50%;
top: 50%;
margin-left: -50px;
margin-top: -50px;
}
2 calc
思路和上一种方法类似。calc的百分比基于父元素计算。因此需要减去子元素宽高的一半。
.parent{
position: relative;
overflow: hidden;
}
.child{
position: absolute;
left:calc(50% - 50px);
top: calc(50% - 50px);
}
未知宽高
1 绝对定位+margin auto
.parent{
position: relative;
}
.child{
margin:auto;
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
}
2 定位+translate
translate用于在平面内进行平移。由于tanslate的百分比是基于自身计算的,因此可以结合定位实现未知宽高的居中
.parent{
position: relative;
}
.child{
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%,-50%);
}
3 flex布局实现居中
利用弹性盒模型实现居中。只需要设置flex父元素的align-items和justice-content为center就可以做到水平垂直居中。是比较简洁实用的一种方案。
缺陷是兼容性不是很好,需要IE9以上版本
.parent {
display: flex;
align-items: center;
justify-content: center;
}
4 gird
代码和flex一样简洁,只需设置父元素display为grid,设置子元素align-self和justify-self为center,即可实现居中效果
缺陷是IE兼容性极其不好
.parent{
display: grid;
}
.child{
align-self: center;
justify-self: center;
}
5 css table
.parent{
display: table-cell;
text-align: center;
vertical-align: middle;
}
.child{
width: auto;
height: auto;
display: inline-block;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端