CSS中IE6下双边距BUG解决方案
来源:互联网 发布:js if else 简写 编辑:程序博客网 时间:2024/05/16 16:13
其实这个问题在刚学习CSS的时候就知道怎样解决了,但是一直不知道为什么会出现这种现象,今天顺便记录一下。
1.为什么会出现双边距BUG?
<style type="text/css"> body,div{padding: 0;margin: 0;} .box{border: 10px solid black;float: left;} .inner{width: 100px;height: 100px;background: red;float: left;margin: 0 100px;} .inner2{width: 100px;height: 100px;background: red;float: left;margin: 0 100px;} } </style><div class="box"> <div class="inner"></div> <div class="inner2"></div></div>
如上述图片实际上我们在一个父亲div中嵌套了一个儿子div元素,给儿子div,儿子div在设置margin-left:100px的时候实际上在IE6中会出现200px的效果。这是因为块级对象默认的display属性值是block,当设置了浮动的同时,还设置了它的外边距就会出现这种情况。也许你会问:“为什么第二个儿子对象和第一个儿子对象之间就不存在双倍边距的BUG”?因为浮动都有其相对应的对象,只有相对于其父对象的浮动对象才会出现这样的问题。第一个儿子对象是相对父对象的,而第二个儿子对象是相对第一个儿子对象的,所以第二个儿子对象在设置后不会出现问题。另外在一些特殊布局中,可能需要组合使用display:block;和display:inline;才能达到预期效果。
2.解决方案
在第一个儿子对象div中设置display: inline
总结:这个现象仅仅出现在block元素中,而inline元素中不会出现这种现象,同时也不会出现上下边距的情况,如果实在不行也可以尝试使用HACK方式,但是不推荐这种方式(不利于后期的维护),也不符合WEB标准。
1 0
- CSS中IE6下双边距BUG解决方案
- IE6下的双边距BUG
- IE6双边距bug*
- 05_02.IE6双边距bug
- IE6双边距bug及其解决办法
- IE6双边距bug及其解决办法
- css 黑客解决IE6,双边距问题
- IE6中CSS常见BUG全集及解决方案
- IE6中CSS常见BUG全集及解决方案
- IE6中CSS常见BUG全集及解决方案
- IE6中CSS常见BUG全集及解决方案
- IE6中CSS常见BUG全集及解决方案
- IE6 下:hover 中bug解决了(纯CSS)
- IE6浮动双边距
- ie6双边距问题
- ie6双边距
- ie6 下双倍 margin bug 及解决方案
- IE6下的CSS BUG枚举
- 初学echarts的excel数据导入遇到的小问题
- PHP 5.5 新特性
- 程序闪退
- DP背包基础
- Combination Sum II
- CSS中IE6下双边距BUG解决方案
- 无线网络覆盖
- boost asio socket
- 互联网不是万能的
- intent实现Activity的跳转和传值
- (4.1.18.6)Android应用中通过AIDL机制实现进程间的通讯实例
- boost log 和 log4cplus
- java验证码
- Linux有用的命令