css两种垂直居中对齐解决方案(小结)
发布时间:2019-04-30 15:29:49 作者:Big_fat_cat 我要评论
这篇文章主要介绍了css两种垂直居中对齐解决方案的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
第一种垂直居中方法
利用vertical-align:middle进行垂直方向上的居中对齐,此方法需要满足的条件:
- 设置父元素的行高line-height等于父元素height的高度
- 子元素必须是行内块级元素display:inline-block;
- 子元素设置vertical-align:middle
- 此方法在开发中不能右浮动(不能靠右边)
下方是完整代码,可以新建一个HTML文件进行测试(绿色的盒子):
<html> <head> <title>导航条</title> <meta charset="utf-8" /> </head> <style> *{ margin:0; padding:0; } .div1{ height:200px; background:yellow; /*行高等于容器高度*/ line-height:200px; } .div2{ width:100px; height:100px; background:green; /*行内块级元素*/ display:inline-block; /*中线和父元素基线上方出对其,参考字母"x"*/ vertical-align:middle; } .div3{ width:100px; height:100px; background:red; display:inline-block; } </style> <body> <div class="div1"> xxxxxxxxxxx <div class="div2" > </div> <div class="div3" > </div> </div> </body> </html>
第一种方法结束。
第二种垂直居中方法
这种方法比较暴力,利用定位解决:
- 父元素开启相对定位
- 子元素绝对定位
- 子元素先向下移动父元素的50%,此时子元素的顶部与父元素的中线对齐了
- 子元素再向上移动自身高度"height"的一半,此时子元素的中线和父元素的中线对齐了
- 此方法可以右对齐,设置子元素right:0px;即可
下方是完整代码,可以新建一个HTML文件进行测试(绿色的盒子):
<html> <head> <title>导航条</title> <meta charset="utf-8" /> </head> <style> *{ margin:0; padding:0; } .div1{ height:200px; background:yellow; /*相对定位开启*/ position:relative; } .div2{ width:100px; height:100px; background:green; /*绝对定位*/ position:absolute; /*可以右对齐*/ right:0px; /*先向下移动父元素的50%,此时子元素的顶部与父元素的中线对齐了*/ top:50%; /*再向上移动自身高度"height"的一半,此时子元素的中线和父元素的中线对齐了*/ margin-top:-50px } </style> <body> <div class="div1"> <div class="div2" > </div> </div> </body> </html>
第二种方法结束。
总结
上面两种方法的特点都是让子元素的中线和父元素的中线对齐。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
- 在前端布局过程中,我们实现水平居中比较简单,一般通过margin:0 auto;和父元素 text-align: center;就能实现。今天小编给大家带来了CSS实现垂直居中的几种方法小结,感兴2019-05-14
- 这篇文章主要介绍了CSS实现垂直居中的七个方法实例代码详解,需要的朋友可以参考下2019-05-06
- 本文给大家分享几种方法介绍css实现元素垂直居中的常用方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2019-04-01
- 这篇文章主要介绍了CSS未知高度垂直居中的实现,详细的介绍了几种方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-11-08
- 这篇文章主要介绍了利用css样式实现表格中字体垂直居中的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-03-16
最新评论