首先我们我们想到居中就是相对于当前窗口,上边距和左边距各一半即可,于是有了下边的css样式:
代码如下 | 复制代码 |
.center |
我们很快发现,问题还没有真正解决,
要实现居中,我们要将对象向左、向上分别移动图片宽度、高度的一半,所以最终的样式如下:
代码如下 | 复制代码 |
.center
Lorem ipsum dolor sit amet, consectetuer adipiscing elit. |
[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]
上一个高度是用的绝对单位px,并且没有隐藏溢出,下一个高度用的单位是相对单位em,并且隐藏了溢出。如果你的浏览器支持放大字体,那么尽情地放大字体,看看会出现什么效果。
二、多行内容居中,且容器高度可变
也很简单,给出一致的 padding-bottom 和 padding-top 就行
代码如下 | 复制代码 |
.middle-demo-2{ |
优点:
1. 同时支持块级和内联极元素
2. 支持非文本内容
3. 支持所有浏览器
缺点:
容器不能固定高度
三、把容器当作表格单元
CSS 提供一系列diplay属性值,包括 display: table, display: table-row, display: table-cell 等,能把元素当作表格单元来显示。这是再加上 vertical-align: middle, 就和表格中的 valign="center" 一样了。
代码如下 | 复制代码 |
.middle-demo-3{ display: table-cell; height: 300px; vertical-align: middle; } |
可惜IE不支持这些属性,不过在其他浏览器上显示效果非常完美。
要注意的是:和一个合法的