css两种垂直居中对齐解决方案(小结)
网站建设 2023-01-28 21:38www.1681989.com免费网站
第一种垂直居中方法
利用vertical-alignmiddle进行垂直方向上的居中对齐,此方法需要满足的条件
- 设置父元素的行高le-height等于父元素height的高度
- 子元素必须是行内块级元素display:le-block;
- 子元素设置vertical-alignmiddle
- 此方法在开发中不能右浮动(不能靠右边)
下方是完整代码,可以新建一个HTML文件进行测试(绿色的盒子)
<html>
<head>
<title>导航条</title>
<meta charset="utf-8" />
</head>
<style>
{
marg:0;
paddg:0;
}
.div1{
height:200px;
background:yellow;
/行高等于容器高度/
le-height:200px;
}
.div2{
width:100px;
height:100px;
background:green;
/行内块级元素/
display:le-block;
/中线和父元素基线上方出对其,参考字母"x"/
vertical-align:middle;
}
.div3{
width:100px;
height:100px;
background:red;
display:le-block;
}
</style>
<body>
<div class="div1">
xxxxxxxxxxx
<div class="div2" >
</div>
<div class="div3" >
</div>
</div>
</body>
</html>
第一种方法结束。
第二种垂直居中方法
这种方法比较暴力,利用定位解决
- 父元素开启相对定位
- 子元素绝对定位
- 子元素先向下移动父元素的50%,此时子元素的顶部与父元素的中线对齐了
- 子元素再向上移动自身高度"height"的一半,此时子元素的中线和父元素的中线对齐了
- 此方法可以右对齐,设置子元素right0px;即可
下方是完整代码,可以新建一个HTML文件进行测试(绿色的盒子)
<html>
<head>
<title>导航条</title>
<meta charset="utf-8" />
</head>
<style>
{
marg:0;
paddg:0;
}
.div1{
height:200px;
background:yellow;
/相对定位开启/
position:relative;
}
.div2{
width:100px;
height:100px;
background:green;
/绝对定位/
position:absolute;
/可以右对齐/
right:0px;
/先向下移动父元素的50%,此时子元素的顶部与父元素的中线对齐了/
:50%;
/再向上移动自身高度"height"的一半,此时子元素的中线和父元素的中线对齐了/
marg-:-50px
}
</style>
<body>
<div class="div1">
<div class="div2" >
</div>
</div>
</body>
</html>
第二种方法结束。
上面两种方法的特点都是让子元素的中线和父元素的中线对齐。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。