css 中 div垂直居中的方法
在说到这个问题的时候,也许有人会问CSS中不是有vertical-align属性来设置垂直居中的吗?即使是某些浏览器不支持我只需做少许的CSS
Hack技术就可以啊!所以在这里我还要啰嗦两句,CSS中的确是有vertical-align属性,但是它只对(X)HTML元素中拥有valign特性的元素才生
效,例如表格元素中的<td>、<th>、<caption>等,而像<div>、<span>这样的元素是没有valign特性的,因此使用vertical-align对它们不起
作用。
单行垂直居中
如果一个容器只有一行文字,那比较简单,设置的方法就是 所在行的高度line-height和实际高度height的值相等即可
例如:
<div class="div1">单行文本的垂直居中,只需设定height和line-height的值一样即可</div>
对应设置的css为:
.div1 {
border: 1px red solid;
height: 25px;
line-height: 25px;
overflow: hidden;
}
多行未知高度文字的垂直居中
这种情况可以通过padding的值相同来实现文字垂直居中的效果
例如:
<div class="div2">多行未知高度的文字垂直居中,只需要设定padding值相同即可</div>
对应的css:
.div2 {
padding: 25px;
border: 1px blue solid;
width: 300px;
}
多行文本固定高度垂直居中
在本文的一开始,我们已经说过CSS中的vertical-align属性只会对拥有valign特性的(X)HTML标签起作用,但是在CSS中还有一个display
属性能够模拟<table>,所以我们可以使用这个属性来让<div>模拟<table>就可以使用vertical-align了。注意,display:table和
display:table-cell的使用方法,前者必须设置在父元素上,后者必须设置在子元素上,因此我们要为需要定位的文本再增加一个<div>元素:
例如:
<div class="div3">
<div class="content">多行文字实现垂直居中,可以模拟table中的vertical-align属性,需要注意display:table和display:table-cell的使用方法
,display:table用于设置在父元素上,display:table-cell,必须设置在子元素上
</div>
</div>
对应的css为:
.div3 {
display: table;
height: 100px;
}
.content {
display: table-cell;
vertical-align: middle;
border: 1px solid green;
width: 400px;
}
这种方式在IE6下不起作用,Internet Explorer 6 并不能正确地理解display:table和display:table-cell,所以在IE6下可以通过绝对定位来实现,但是IE6一般不再考虑的范围内。
最新文章
- copy()之绝版应用
- 利用反卷积神经网络可视化CNN
- BZOJ1588——[HNOI2002]营业额统计
- Mac OSX Versions输入username按1下都会出现2个字符,并且不能create,解决方法
- 夺命雷公狗—angularjs—7—多条数据的遍历
- log4j配置文件详细解释
- mysql学习笔记之基础篇
- python学习之-成员信息增删改查
- JS 语言核心(JavaScript权威指南第六版)(阅读笔记)
- 你不可不知的iOS与Android差异点!
- SpringBoot学习笔记(2) Spring Boot的一些配置
- Facebook主页照片和封面照片的尺寸要求
- Delphi中统一显示表格字段名的高效方法
- 高级php面试题转载
- 20172325 2017-2018-2 《Java程序设计》第十一周学习总结
- sql server中的go
- 基于scrapy的分布式爬虫抓取新浪微博个人信息和微博内容存入MySQL
- 条款47:请使用traits class表示类型信息
- 【LeetCode】005. Longest Palindromic Substring
- python 集合和深浅copy