CSS居中完全解决方案

上次面试面试官问到了,问了个定宽局中和不定宽局中,下来我把所有有关CSS居中都总结了一下

原文摘自我的前端博客,欢迎大家来访问

水平居中

行内元素

把行内元素嵌套在一个DIV中,并且在DIV中设置以下样式

a{
		text-align: center;
	}

块级元素

对于定宽的块级元素,我们要设置起margin-top,margin-right 为auto

.center{
		margin: 0 auto;
	}

多个块级元素(inline-block)

多个块级元素,我们将其display设置为inline-block;然后将父级元素设置一下属性

div{
		text-align: center;
	}

多个块级元素(flex)

设置需要水平居中的块状元素的父元素display为flex ,并且justify-content属性为center即可

body{
	  display: flex;
	  justify-content: center;
	}

垂直居中

单行 行内元素

将行内元素的height和line-height设置为一致即可

a{
	  height: 200px;
	  line-height:200px;  
	}

多行 行内元素

如果行内元素文字过多产生多行,则在父级元素设置display: table-cell;vertical-align:middle;

.container{
		width: 300px;
		height: 300px;
		display: table-cell;
		vertical-align:middle;
	}

已知高度的块级元素

将块级元素设置绝对定位,top为50%,margin-top:-height/2

div{
	  height: 100px;
	  position: absolute;
	  top: 50%;
	  margin-top: -50px;
	  padding:0; 
	}

未知高度的块级元素

使用CSS translate,将块级元素设置绝对定位,top为50%,transform: translateY(-50%);

div{
	  position: absolute;
	  top: 50%;
	  transform: translateY(-50%);
	  padding:0; 
	}

水平垂直居中

已知高度、宽度的元素

将块级元素设置绝对定位,top为50%,left:50%;margin-top:-height/2;margin-left:-width/2

div{
		width: 150px;
		height: 150px;
		position: absolute;
		top: 50%;
		left: 50%;
		margin-top: -75px;
		margin-left: -75px;
	}

已知高度、宽度的元素(flex)

给父级使用flex布局

div{
		display: flex;
		justify-content:center;
		align-items: center;
	}

未知高度、宽度的元素

使用CSS translate

div{
	    position:absolute;
		top:50%;
		left:50%;
		-webkit-transform:translate(-50%,-50%);
		-moz-transform:translate(-50%,-50%);
		transform:translate(-50%,-50%);
	}
posted @   hacke2  Views(616)  Comments(3Edit  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
点击右上角即可分享
微信分享提示