CSS 解决未知高度垂直居中实现代码


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

非标准浏览器只能在子元素里设距顶部50%,里面再套个元素距顶部-50% 来抵消。

CSS

复制代码
代码如下:

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 id="outer">
<div id="middle">
<div id="inner" class="greenBorder">
</div>
</div>
</div>

以上CSS代码的优点是没有hacks,采用了IE不支持的CSS2选择器#value[id]。

CSS2选择器#value[id]相当于选择器#value,但是Internet Explorer不支持这种类型的选择器。同样地.value[class],相当于.value,这些只有标准浏览器能读懂。

测试:Firefox1.5、Opera9.0、IE6.0、IE5.0通过。



提示:您可以先修改部分代码再运行



相关阅读:
Readonly和Disabled的区别
JBuilder2005实战JSP之日志和部署(5)
简单的防盗链功能代码(iframe)
BSD下vi用法详解
对squid中refresh_pattern的一些理解和建议
PHP教程:TEA算法实现
CSS高级技巧:网页布局
网页设计之5种简单的XHTML网页表单
百度有啊 CSS圆角实现代码
Mootools 1.2教程 类(一)
ASP.NET页面借助IFrame提交表单数据所遇到问题的解决方法分享
网页设计参考 firefox 默认样式
jquery 简单图片导航插件jquery.imgNav.js
xhtml的标签和元素介绍
快速导航

Copyright © 2016 phpStudy | 皖ICP备18014864号-4