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