登录  /  注册

兼容各个浏览器的未知高度div垂直居中效果_html/css_WEB-ITnose

php中文网
发布: 2016-06-24 11:41:22
原创
1461人浏览过

兼容各个浏览器的未知高度div垂直居中效果:
让div垂直居中与它的父对象中,并不像是让div在父元素中水平居中那么简单,只要简单的为此元素设置margin:0px auto即可,虽然将一些属性配合使用也可以将div垂直居中与父元素中,但是在某些浏览器中并不兼容,下面就介绍一种兼容各大浏览器的方式。
先看一段代码实例:

<!DOCTYPE html><html><head><meta charset="utf-8"><meta name="author" content="http://www.51texiao.cn/" /><title>蚂蚁部落</title> <style type="text/css"> .parent {   width:200px;   height:200px;   background-color:green;   display:table-cell;   vertical-align:middle; } .children {   background-color:red;   width:80px;   text-align:center;   margin:0px auto; } </style> </head> <body> <div class="parent">   <div class="children">蚂蚁部落</div> </div> </body> </html>
登录后复制

以上代码在标准浏览器中运行一切正常,能够将子元素在父元素中垂直居中对齐,但是IE6和IE7就并非这么给力了,所以代码需要进行改造,以兼容IE6和IE7浏览器,但是如果仅仅是添加CSS兼容代码,不在结构上进行变化的话,很难实现兼容IE6和IE7,下面就对以上代码调整如下:

<!DOCTYPE html><html><head><meta charset="utf-8"><meta name="author" content="http://www.51texiao.cn/" /><title>蚂蚁部落</title> <style type="text/css"> .parent {   width:200px;   height:200px;   background-color:green;   position:relative;   display:table; } .middle {   display:table-cell;   vertical-align:middle;   *position:absolute;   *top:50%;   *left:50%; } .children {   background-color:red;   width:80px;   text-align:center;   margin:0px auto;   *position:relative;   *top:-50%;   *left:-50%; } </style> </head> <body> <div class="parent"> <div class="middle">    <div class="children">蚂蚁部落</div> </div> </div> </body> </html>
登录后复制

以上代码实现了将div垂直居中效果。此段代码大家不必看作为是第一段代码的修改版本,可以看做一个完全的新版本,下面就简单介绍一下次代码是如何实现此效果的:
一.实现思想:
由于IE6和IE7不支持display:table-cell和display:table,所以middle对象的高度和children对象的高度是一样的,当然如果children对象不设置宽度的话,它们尺寸是完全一样的。将middle对象在IE6和IE7中使用绝对定位,并且参考对象是parent对象,并且将它的top值设置为50%,这样middle对象的上边缘的位置恰好是parent对象垂直方位的中间位置。同样让children对象也使用定位,然后将它的top值设置为-50%,这样它的上移了middle的一半高度尺寸,这样children对象的中心位置也就位于parent对象的垂直方位的中间位置,这样就实现了children对象的垂直居中效果。这里可能有朋友会问,为什么其他标准浏览器不使用此方式,这是因为如果middle对象没有设置高度的话,设置的top属性并不能生效。以下图片是将middle背景颜色设置为蓝色后在IE6和IE7下运行效果图:

二.知识点说明:
1.星号(*)是为了兼容IE6和IE7浏览器。
2.parent对象中要添加display:table和middle对象中的display:table-cell相对应,否则在middle元素尺寸和内容自适应,而不是和parent元素的尺寸相同,这样就无法实现在标准浏览器中使children对象垂直居中了。

原文地址是:http://www.51texiao.cn/div_cssjiaocheng/2015/0501/503.html

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号