博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
div+css总结—FF下div不设置高度背景颜色或外边框不能显示
阅读量:6419 次
发布时间:2019-06-23

本文共 1103 字,大约阅读时间需要 3 分钟。

hot3.png

div+css总结—FF下div不设置高度背景颜色或外边框不能显示的解决方法

在使用div+css进行网页布局时,如果外部div有背景颜色或者边框,而不设置其高度,在IE浏览器下显示正常。但是使用Firefox/opera浏览时却出现最外层Div的背景颜色和边框不起作用的问题。

大体结构

 
 
css文件:(只写出了最主要的部分css代码:定义了最外层div的背景颜色和边框,同时定义了里面的div是浮动的)
.outer{border:#F00 1px solid; background:#FF9 repeat;}
.inner1,.inner2{float:left;}

在IE中显示正常,如图1div+css总结鈥擣F下div不设置高度背景颜色或外边框不能显示

(图1)

在FF中显示不正常,边框线和背景色都不能正常显示,如图2

div+css总结鈥擣F下div不设置高度背景颜色或外边框不能显示

(图2)

从网上查阅了一些资料,才对这个问题有了大体的认识。

原因分析:由于在Firefox和opera中:如果里面的DIV是浮动的(float)而母体不会去计算子体float之后的height。而在IE中支持这种计算,所以IE下正常。

所以出现这种问题有两个前提:1.外部div没有设置高度;2. 内部div是浮动的(带有float属性)。

解决方法:
给外部div直接设置高度(不推荐),因为很多时候我们并不知道外部div的高度,我们希望靠里面的div来根据内容自动抻开外边的div,除非你确定的知道外部的div的高度的情况下,所以不建议使用这种方法。
方法一:
在内部最后一个FLOAT的div后加一个清除浮动(推荐),这样firefox和opera就把里面不当成浮动,会自动计算内部div高度
 
<divclass="outer">
 
<divclass="inner1">inner1</div>
 
<divclass="inner2">inner2</div>
 
<div style="clear:both"></div>
</div>
 
 

方法二:
在.outer中加一句overflow:hidden;(这种方法我不是特别理解,但是经过试验,也是可以解决这个问题的div+css总结鈥擣F下div不设置高度背景颜色或外边框不能显示的解决方法)

 

<div class="outer" style="overflow:hidden;">

 <divclass="inner1">inner1</div>
 <divclass="inner2">inner2</div>
</div>

overflow属性规定当内容溢出元素框时发生的事情。如果外层设置了高度,并且高度小于内层占的实际高度,则内层一部分内容会被隐藏。

转载于:https://my.oschina.net/songjianguo/blog/729038

你可能感兴趣的文章
理解RESTful架构
查看>>
Linux自动压缩备份目录文件与恢复
查看>>
Android 图片相关整理
查看>>
创建一个Hello World(React),组件的作用
查看>>
java中的context
查看>>
Spring源码阅读——3
查看>>
使用ZXing生成可供手机识别的二维码
查看>>
griedview setOnItemLongClickListener 无效
查看>>
pyqt在控件上创建图片
查看>>
邮件服务器被***根源及解决方案
查看>>
Linux IO实时监控iostat命令详解
查看>>
企业软件仓库部署及应用案例(基于CentOS 6的YUM源)
查看>>
探寻路径
查看>>
微访谈活动-企业微博2.0与数据微博营销(转)
查看>>
Android生命周期
查看>>
优酷土豆:财报不是问题!
查看>>
紧急维护,阿里云服务器抢修记
查看>>
linux工具使用
查看>>
站长怎样理性选择虚拟主机
查看>>
linux文件系统\环境变量\帮助文件
查看>>