论坛交流
首页办公自动化| 网页制作| 平面设计| 动画制作| 数据库开发| 程序设计| 全部视频教程
应用视频: Windows | Word2007 | Excel2007 | PowerPoint2007 | Dreamweaver 8 | Fireworks 8 | Flash 8 | Photoshop cs | CorelDraw 12
编程视频: C语言视频教程 | HTML | Div+Css布局 | Javascript | Access数据库 | Asp | Sql Server数据库Asp.net  | Flash AS
当前位置 > 文字教程 > div+css布局教程
Tag:css,入门,技巧,div,实例,示例,菜单,布局,web2.0,ul,li,经验,列表,web标准,xhtml,web标准,浏览器,兼容,css hack,表格,视频教程

如何实现未知高居垂直居中?

文章类别:div+css布局 | 发表日期:2008-9-26 11:13:17

  
  尽管我们知道CSS的vertical-align特性,但是并不能有效解决未知高度的垂直居中问题(在一个div容器里有未知高度的文本或图片的情况下)。

  标准浏览器如Mozilla,Opera等,可将父级元素显示方式设定为TABLE(display: table;) ,内部子元素定为table-cell (display: table-cell),通过vertical-align特性使其垂直居中,但非标准浏览器是不支持的。依然解决不了未知高居垂直居中。

  非标准浏览器只能在子元素里设距顶部50%,里面再套一个容器元素距顶部-50% 来抵消。最终实现未知高居垂直居中的设置。

  看下面的CSS代码:

div css xhtml xml Example Source Code Example Source Code [www.21shipin.com]
body {padding: 0; margin: 0;}
body,html{height: 100%;}
#outer {height: 100%; overflow: hidden; position: relative;width: 100%; background:ivory;}
#outer[id] {display: table; position: static;}
#middle {position: absolute; top: 50%;} /* for explorer only*/
#middle[id] {display: table-cell; vertical-align: middle; position: static;}
#inner {position: relative; top: -50%;width: 400px;margin: 0 auto;} /* for explorer only */
div.greenBorder {border: 1px solid green; background-color: ivory;}

  下面是XHTML代码:

div css xhtml xml Example Source Code Example Source Code [www.21shipin.com]
<div id=\"outer\">
<div id=\"middle\">
<div id=\"inner\" class=\"greenBorder\">
</div>
</div>
</div>

  我们来看看最终(未知高居垂直居中)效果的实例演示:

div css xhtml xml Source Code to Run Source Code to Run [www.21shipin.com]

[ 可先修改部分代码 再运行查看效果 ]

  
视频教程列表
文章教程搜索
 
div+css推荐教程
div+css热门教程
看全部视频教程
购买方式/价格
购买视频教程: 咨询客服
tel:15972130058