首页 > 编程 > HTML > 正文

关于html水平垂直居中的问题小结

2019-10-26 17:17:59
字体:
来源:转载
供稿:网友

最近遇到很多居中的问题,就花点时间总结了一下放在这里,以后找也方便

1.居中文本

复制代码
代码如下:
<div class="wrap">
我在中间……
</div>
.. height+line-height+text-center(只能居中单行)
.wrap{
width:px;
height:px;
border:px solid red;
text-align: center;
line-height: px;
}

ps:text-align:center只是将元素下面的内联元素居中显示
1.2display:table-cell(多行固定高度居中)

复制代码
代码如下:
.wrap{
width:px;
height:px;
border:px solid red;
text-align: center;
display:table-cell;
vertical-align: middle;
}

display:table-cell:ie67不管用,最好配合display:table;一起用
ie67下:(以后也不用了,不过也放这儿吧)
方法一:(通过em标签高度与父级等高,所以span和em居中就相当于span在父级居中)
 
复制代码
代码如下:
<div class="wrap">
<span>
我在中间…… 我在中间…… 我在中间…… 我在中间……
</span>
<em></em>
</div>
.wrap{
width:px;
height:px;
border:px solid red;
text-align: center;
}
.wrap span{
vertical-align: middle;
display:inline-block;
width:px;
}
.wrap em{
height:%;
vertical-align: middle;
display:inline-block;
}

方法二:(通过给子元素增加一个绝对定位的父级标签,再配合子元素的相对定位水平垂直居中)
 

复制代码
代码如下:
<div class="wrap">
<span class="span">
<span class="span">我在中间…… 我在中间…… 我在中间…… 我在中间……</span>
</span>
</div>
.wrap{
width:px;
height:px;
border:px solid red;
display:table;
position:relative;
overflow: hidden;
}
.wrap .span{
display:table-cell;
vertical-align: middle;
text-align: center;
*position:absolute;
top:%;
left:%;
}
.wrap .span{
*position:relative;
top:-%;
left:-%;
}

1.3padding(内填充,不用多说)

复制代码
代码如下:
.wrap{
width:px;
border:px solid red;
padding:px ;
}
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表