您的位置:首页 > Web前端 > CSS

关于CSS中的居中问题的思考及解决方案

2011-10-15 11:05 423 查看
根据CSS中块级元素和行内元素的不同特征,其居中显示的方式也有差异,下面就水平和竖直居中的情况做一总结:

1.水平居中

1.1 给父元素设置text-aglin:center;可以实现文本、图片等行内元素的水平居中。

1.2 确定宽度的块级元素的水平居中是通过设置margin-left和margin-right的值为auto来实现。

1.3 对于宽度值不确定的块级元素的居中可以使用以下三种方式,可根据实际情况选择不同方案:

1.3.1 改变块级元素的display值为inline,然后使用text-aglin:center来实现居中,

但此做法的缺点是将块级元素转化为行内元素后就无法设置长宽,当然还有行内元素的其他局限性。

1.3.2 利用table。table本身不是块级元素(display的常用值包含block,compact,inline,table,none,marker).

其宽度靠其单元格中的内部元素的宽度“撑起”,即使不设置宽度也可以利用margin-left/right:auto来实现居中。

当然,使用table标签将会明显增加代码中的无语义标签。

1.3.3 通过给父级元素设置float和position:relative以及left:-50%,给子元素设置position:relative和left:-50%,

也可以实现水平居中,但是relative的位置属性不好控制。

2.竖直居中

2.1 父元素高度不确定的文本、图片、块级元素的竖直居中是通过设置父元素相同的上下边距实现的。

2.2 父元素高度确定的单行文本的竖直居中是给父元素设置line-height:(父元素的height值)来实现。

2.3 父元素高度确定的多行文本、图片、块级元素的竖直居中,分三种情况处理:

2.3.1 父元素为td和th时,可用vertical-align

2.3.2 对于不是此类型的父元素在Firefox和IE8下可用display:table-cell来激活成td或th类型

2.3.3 如果以上两种情况都不满足,则需要给元素添加表格标签,so sad~~~
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: