多层DIV嵌套-父级DIV样式无效.txt

发布:2013-08-13 12:55   点击779次   评论:0

多层DIV嵌套时 父级DIV样式无效的问题
http://www.chinaz.com/design/2009/0810/86084.shtml


我们做DIV+CSS布局时常常如下的做多层DIV的嵌套,可是我们却发现不管是在IE8 还是FF下都层在毛病。

在IE8和FF下,DIV 1的边框变成了一条直线,并没有随着内部两个DIV的内容而撑大,原来是因为如果父级DIV没有定义高度,并且内容为空时所定义样式将无效。

1、当我们这样直接使用时

<div class="*">

……

ul,p,table,span等文本级别元素

</div>

这个时候我们发现div的样式可以正确应用,我们可以通过给div加边框就可以看出,这个时候DIV的边框是包含了整个文本区域

2、当我们这样用时候

<div class="1">

       <div class="2"></div>

       <div class="3"></div>

</div>

这个时候我们发现问题出现了,在IE8和FF下,DIV 1的边框变成了一条直线,在最上面,并没有随着内部两个DIV的内容而撑大,原来是因为如果父级DIV没有定义高度,并且内容为空时所定义样式将无效,或我们直观看到的就好似不自动伸长的错误,上网和网友讨论很久,经过我可爱的百度,不停的转换关键字搜索,终于找到了解决办法,屡试不爽。

定义这样一个样式表

/*解决FF,IE8,DIV嵌套时,外部DIV没有定义高度,并且内部无内容只有有内嵌套的DIV时,外DIV不能被撑大的问题*/
.box:after{ content:".";height:0px;display:block; clear:both; visibility: hidden;}

我们对div 1 使用即可 

<div class="1 box">

在刷新我们的网页试试,怎么样,终于解决了……

样式效果可以看我的网站:lushuncheng.cn

关于 GitHub 导航 部门 反馈

提示:`/home.php`入口数据仅为演示功能,不构成任何交易凭证,也不承担相关风险和责任!

Copyright © 2011-2018 xxxxx.com All rights reserved.

Run:3.668/39.435(ms); 7(sql)/2.879(MB); comm:news/detail; Upd:2025-01-11 03:53:56