CSS3如何实现元素水平居中、垂直居中
CSS3如何实现元素水平居中、垂直居中
水平居中
- 01
行内元素 如果被设置元素为文本、图片等行内元素时,水平居中是通过给父元素设置 text-align:center来实现的
- 02
定宽块状元素 当被设置元素为块状元素时用 text-align:center 就不起作用了。满足定宽和块状两个条件的元素是可以通过设置 “左右margin”值为“auto”来实现居中的。
- 03
在实际工作中我们会遇到需要为“不定宽度的块状元素”设置居中,比如网页上的分页导航,因为分页的数量是不确定的,所以我们不能通过设置宽度来限制它的弹性。
- 04
不定宽块状元素1 1)为需要设置的居中的元素外面加入一个 table 标签 ( 包括 <tbody>、<tr>、<td> )。 2)为这个 table 设置“左右 margin 居中。
- 05
不定宽块状元素2 改变块级元素的 dispaly 为 inline类型,然后使用 text-align:center来实现居中效果
- 06
不定宽块状元素3 通过给 父元素设置 float,然后给 父元素设置 position:relative和 left:50%, 子元素设置 position:relative 和 left:-50%来实现水平居中
垂直居中
- 01
父元素高度确定的单行文本 垂直居中的方法是通过 设置父元素的 height 和 line-height 高度一致来实现的
- 02
说到竖直居中,css 中有一个用于竖直居中的属性 vertical-align,但这个样式只有在父元素为 td 或 th 时,才会生效
- 03
父元素高度确定的多行文本1 使用 插入 table (包括tbody、tr、td)标签,同时设置 vertical-align:middle(因为 td 标签默认情况下就默认设置了 vertical-align 为 middle,所以我们不需要显式地设置了)
- 04
父元素高度确定的多行文本2 在 chrome、firefox 及 IE8 以上的浏览器下可以设置块级元素的 display:table-cell, vertical-align:middle,但注意 IE6、7 并不支持这个样式。