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

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

大体结构
<div class="outer">
  <div class="inner1"></div>
  <div class="inner2"></div>
</div>
css文件:(只写出了最主要的部分css代码:定义了最外层div的背景颜色和边框,同时定义了里面的div是浮动的)
.outer{border:#F00 1px solid; background:#FF9 repeat;}
.inner1,.inner2{float:left;}
在IE中显示正常,如图1

div+css总结—FF下div不设置高度背景颜色或外边框不能显示的解决方法(图1)
在FF中显示不正常,边框线和背景色都不能正常显示,如图2

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

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

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

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

解决方法:
给外部div直接设置高度(不推荐),因为很多时候我们并不知道外部div的高度,我们希望靠里面的div来根据内容自动抻开外边的div,除非你确定的知道外部的div的高度的情况下,所以不建议使用这种方法。
方法一:
在内部每个div后加一个清除浮动(推荐),这样firefox和opera就把里面不当成浮动,会自动计算内部div高度
<div class="outer">
  <div class="inner1"></div>
  <div class="inner2"></div>
  <div style="clear:both;"></div>
</div>
方法二:
在.outer中加一句overflow:hidden;(这种方法我不是特别理解,但是经过试验,也是可以解决这个问题的div+css总结—FF下div不设置高度背景颜色或外边框不能显示的解决方法)
overflow 属性规定当内容溢出元素框时发生的事情。如果外层设置了高度,并且高度小于内层占的实际高度,则内层一部分内容会被隐藏。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 CSS 中的 linear-gradient() 函数来实现 div 的渐变背景和渐变边框。 下面是一个设置渐变背景和渐变边框的示例代码: ```html <div class="gradient-box"></div> ``` ```css .gradient-box { width: 200px; height: 200px; background: linear-gradient(to bottom right, #ff0080, #ff8c00); border: 2px solid; border-image: linear-gradient(to bottom right, #ff0080, #ff8c00) 1; } ``` 在上面的代码中,使用 `background` 属性来设置 div 的渐变背景。`linear-gradient()` 函数中的参数 `to bottom right` 表示渐变方向为从左上角到右下角,`#ff0080` 和 `#ff8c00` 分别表示渐变的起始颜色和结束颜色。 使用 `border` 属性来设置 div边框,同时使用 `border-image` 属性来设置边框的渐变。`linear-gradient()` 函数中的参数同样表示渐变方向,`1` 表示边框宽度为 1 像素。 需要注意的是,`border-image` 属性在一些浏览器中可能不被支持,此时可以使用 `background-clip` 属性来实现相同的效果。代码如下: ```css .gradient-box { width: 200px; height: 200px; background: linear-gradient(to bottom right, #ff0080, #ff8c00); border: 2px solid transparent; padding: 2px; background-clip: content-box, border; } ``` 在上面的代码中,使用 `padding` 属性来为 div 添加内边距,同时将 `border` 属性的颜色设置为 `transparent`,使边框不可见。使用 `background-clip` 属性来指定背景的绘制区域,`content-box` 表示背景仅在内容区域绘制,`border` 表示背景在边框区域绘制。这样,就可以实现相同的渐变边框效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值