关于html水平垂直居中的问题小结_HTML/Xhtml_网页制作
程序员文章站
2022-04-30 08:47:31
...
最近遇到很多居中的问题,就花点时间总结了一下放在这里,以后找也方便
我在中间……
.. 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在父级居中)
我在中间…… 我在中间…… 我在中间…… 我在中间……
.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;
}
我在中间…… 我在中间…… 我在中间…… 我在中间……
.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:-%;
}
.wrap{
width:px;
border:px solid red;
padding:px ;
}
2.1position:absolute+margin负值(必须要有宽高,才能计算margin)
.wrap{
width:px;
height:px;
position:absolute;
top:%;
left:%;
margin-top:-px;
margin-left:-px;
border:px solid red;
}
.wrap span{
width:px;
height:px;
background:red;
position: absolute;
top:%;
left:%;
margin-top:-px;
margin-left:-px;
}
1.居中文本
复制代码
代码如下:我在中间……
.. 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在父级居中)
复制代码
代码如下:我在中间…… 我在中间…… 我在中间…… 我在中间……
.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;
}
方法二:(通过给子元素增加一个绝对定位的父级标签,再配合子元素的相对定位水平垂直居中)
复制代码
代码如下:我在中间…… 我在中间…… 我在中间…… 我在中间……
.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 ;
}
2.居中元素
复制代码
代码如下:2.1position:absolute+margin负值(必须要有宽高,才能计算margin)
复制代码
代码如下:.wrap{
width:px;
height:px;
position:absolute;
top:%;
left:%;
margin-top:-px;
margin-left:-px;
border:px solid red;
}
.wrap span{
width:px;
height:px;
background:red;
position: absolute;
top:%;
left:%;
margin-top:-px;
margin-left:-px;
}
ps:CSS实现DIV水平居中和上下垂直居中
复制代码
代码如下:水平垂直居中原理介绍
这里使用了绝对定位position:absolute,使用left和top设置对象距离上和左为50%,但如果设置50%,实际上盒子是没有实现居中效果,所以又设置margin-left:-200px;margin-top:-100px;,这里有个技巧是,margin-left的值是宽度一半,margin-top的值也是对象高度一半,同时设置为负,这样就实现了水平和垂直居中。
推荐阅读
-
html中的水平居中和垂直居中的问题。(固定高度与高度不定)_html/css_WEB-ITnose
-
关于多行文字水平垂直居中的一点研究_html/css_WEB-ITnose
-
关于html水平垂直居中的一些总结吧_html/css_WEB-ITnose
-
html中的水平居中和垂直居中的问题。(固定高度与高度不定)_html/css_WEB-ITnose
-
XHTML标签的自关闭的写法应该注意的问题_HTML/Xhtml_网页制作
-
XHTML标签的自关闭的写法应该注意的问题_HTML/Xhtml_网页制作
-
html中的水平居中和垂直居中的问题。(固定高度与高度不定) - DD狗
-
关于XHTML的H1标记的位置_HTML/Xhtml_网页制作
-
HTML的一些关于颜色方面的参考_HTML/Xhtml_网页制作
-
一些HTML代码的编写风格建议小结_HTML/Xhtml_网页制作