办法一:
利用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;
bac公斤round:yellow;
/*行高等于容器高度*/
line-height:200px;
}
.div2{
width:100px;
height:100px;
bac公斤round:green;
/*行内块级元素*/
display:inline-block;
/*中线和父元素基线上方出对其,参考字母"x"*/
vertical-align:middle;
}
.div3{
width:100px;
height:100px;
bac公斤round: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;
bac公斤round:yellow;
/*相对定位开启*/
position:relative;
}
.div2{
width:100px;
height:100px;
bac公斤round:green;
/*绝对定位*/
position:absolute;
/*能够右对齐*/
right:0px;
/*先向下移动父元素的50%,此时子元素的顶部与父元素的中线对齐了*/
top:50%;
/*再向上移动自己高度"height"的一半,此时子元素的中线和父元素的中线对齐了*/
margin-top:-50px
}
</style>
<body>
<div class="div1">
<div class="div2" >
</div>
</div>
</body>
</html>
我是学姐,一个正在创业的前端工程师,倘若你一样迷茫不晓得前端该怎样学习,能够加入我的自学团,会有知识分享,匹配学习伙伴,还能够参加我组织的上线项目及活动。
想加入的伙伴给我留言或直接私信。
作者:编程匠工
链接:css实现div垂直水平居中的2种常用办法
|