浮动“塌陷”

float参见:

  http://www.cnblogs.com/bigtreei/p/8110090.html

  http://www.w3school.com.cn/css/css_positioning_floating.asp

·使用浮动(float)的一个比较疑惑的事情是他们怎么影响包含他们的父元素的。如果父元素只包含浮动元素,且父元素未设置高度和宽度的时候。

那么它的高度就会塌缩为零。如果父元素不包含任何的可见背景,这个问题会很难被注意到,但是这是一个很重要的问题。在这里我们可以称为“塌陷”。如下图

代码:

<div>

<div><span>块1</span> float:left</div>

<div><span>块2</span> float:left</div>

<div><span>块3</span> float:left</div>

</div>

解决“塌陷”三个方法
1.在使用float元素的父元素结束前加一个高为0宽为0且有clear:both样式的div 如下图

代码:

<div>

<div><span>块1</span> float:left </div>

<div><span>块2</span> float:left</div>

<div><span>块3</span> float:left</div>

<div></div>

</div>

2.在使用float元素的父元素添加overflow:hidden;如下图

代码:

<div>

<div><span>块1</span> float:left </div>

<div><span>块2</span> float:left</div>

<div><span>块3</span> float:left</div>

</div>

3 .使用after伪对象清除浮动 如下图

代码:

<div>

<div><span>块1</span> float:left </div>

<div><span>块2</span> float:left</div>

<div><span>块3</span> float:left</div>

</div>

IE6双边距问题

·IE6双边距问题:一个居左浮动(float:left)的元素放置进一个容器盒(box),并在浮动元素上使用了左边界(margin-left) 在ie6内便产生双倍边距。如下图

IE7、IE8和Firefox

 IE6

代码:
<div>
<div><span>块1</span> float:left marin_left:10px; </div>

<div><span>块2</span> float:left marin_left:10px; </div>

<div><span>块3</span> float:left</div>

</div>
这个Bug仅当浮动边界和浮动元素的方向相同时出现在浮动元素和容器盒的内边缘之间,在这之后的任意有着相似边界的浮动元素不会呈现双倍边界。只有特定的浮动行的第一个浮动元素会遭遇这个Bug。像居左的情况一样,双倍边界同样神秘地显示在居右的相同方式。

解决IE6双边距问题: display:inline; 使浮动忽略 如下图

代码:
<div>

<div><span>块1</span>float:left; marin_left:10px; display:inline; </div>

<div><span>块2</span> float:left marin_left:10px; </div>

<div><span>块3</span> float:left</div>

</div>

IE6文本产生3象素的bug

·浮动IE6文本产生3象素的bug时指挨着浮动元素的文本会神奇的被踢出去3像素,好像浮动元素的周围有一个奇怪的力场一样。如下图

 firefox、IE7、IE8

 IE6

代码:
<div>

<div>float:left;width:200px; height:100px; </div>

<div> margin-left:200px; width:150px; height:100px; </div>

</div>
解决浮动IE文本产生3象素问题以下有两个方法
1.左边对象浮动,右边采用外补丁的左边距来定位  如下图
 firefox、IE7、IE8、IE6

代码:
<div>

<div>margin-right:-3px; float:left;width:200px; height:100px; </div>

<div>width:150px; height:100px; </div>

</div>
2.左边对象浮动,右边对象也浮动 如下图

 firefox、IE7、IE8、IE6

代码:
<div>

<div> float:left; width:200px;height:100px; </div>

<div> float:left;width:150px; height:100px; </div>

</div>

IE6,IE7 中,底边距 bug

·IE6,IE7 中,底边距 bug是当浮动父元素有浮动子元素时,这些子元素的底边距会被父元素忽略掉。如下图

 firefox

 IE6、IE7

代码:
<div>

<div> margin-bottom:10px; float:left;</div>

<div> margin-bottom:10px; float:left;</div>

<div> margin-bottom:10px; float:left;</div>

<div> margin-bottom:10px; float:left;</div>

</div>
解决IE6,IE7 中,底边距 bug:用父元素的底内补白(padding)代替。如下图

 firefox、IE7、IE8、IE6

代码:
<div>

<div>float:left;</div>

<div>float:left;</div>

<div> float:left;</div>

<div>float:left;</div>

</div>

这个方法的缺点是不能换行,如果想要换行的话,建议将浮动父元素的浮动子元素设置padding值。

最新文章

  1. Bootstrap &lt;基础十八&gt;面包屑导航(Breadcrumbs)
  2. 【web前端面试题整理06】成都第一弹,邂逅聚美优品
  3. mysql中select五种子句和统计函数
  4. 全零网络IP地址0.0.0.0表示意义详谈
  5. 使用log4net
  6. VNC与Windows之间的复制粘贴
  7. 手势交互之GestureOverlayView
  8. js兼容性 - 动态删除script标签后 ,定义的函数是否执行
  9. hadoop高可用集群搭建小结
  10. A - Next_permutation
  11. 【Mysql】复制表结构+数据(转)
  12. POST方式提交乱码解决
  13. python命令行参数解析模块argparse和docopt
  14. iOS 高级去水印,涂鸦去水印
  15. 新浪某站CRLF Injection导致的安全问题
  16. [剑指Offer]52-两个链表的第一个公共节点
  17. highlightjs 详解
  18. JDBC数据库基本操作
  19. 全面解析PHP面向对象的三大特征
  20. 【bzoj1483】 HNOI2009—梦幻布丁

热门文章

  1. Idea maven多模块项目有些加载不出来
  2. unity, inspector debug
  3. unity, get Canvas Scaler referenceResolution
  4. Atitit.手机验证码的破解---伪随机数
  5. Atitit.一些公司的开源项目&#160;重大知名开源项目attilax总结
  6. hdu1584 A strange lift (电梯最短路径问题)
  7. C# AppDomain 类
  8. linux下1号进程的前世(kthread_init)今生(init)
  9. 2015 Spark 将走向哪里?
  10. Unity3D学习笔记——IDE工作视图