css水平与垂直居中

以下内容是我在学习中发现总结,并学习前辈们的经验所写的。以下方法均是在现代浏览器中测试得到的。

一、水平居中

  对于块级元素的居中设置:margin:0 auto;

对于内联元素的水平居中,在其父元素中设置:text-align:center;

效果图如下:

  

代码如下:

                

二、垂直居中
    1.对于单行文本,设置line-height为所需要的box的高度
    
   
   tips:行高不要用成百分比表示,会导致错误。
2.对于块级元素,使用绝对定位和负外边距。

  原理:通过绝对定位使左上角居中,然后通过负外边距使块级元素居中。

  适用于宽度和高度已经确定的块级元素。


   

 

3.对于块级元素,使用绝对定位和tranform实现垂直居中。
实现效果如同2。使用transform实现块级元素的居中。

代码如下:
4.对于块级元素,使用绝对定位和margin实现居中。
效果图如2所示。
原理:使top和bottom相等,实现垂直居中,使left和right相等,实现水平居中。


5.对父元素使用外边距实现垂直居中。

原理:对父元素设置相等的上下内边距,但是不能设置高度,让其自然撑开。


6.使用基准元素。。

原理:设置一个基准元素,高度为父元素高度的一半,在利用margin-top取值,使元素垂直居中。


 

效果图如下:

 

7.使用flex布局使块级元素和文本元素居中

效果图如2所示:

   

8.使用flex布局

调整主轴的方向,与7方法相似。

9、实现图片的垂直居中:同时使用line-height和vertical-align。

 

10.使用表格居中

适用于图片墙之类的居中。

  

欢迎大家指出小白的错误,感谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值