开胃小菜
- 来看一个实验:现在有两个div,div身上没有任何属性。每个div中都有li,这些li都是浮动的。
清除浮动方法1:给浮动的元素的祖先元素加上高度
- 如果一个元素要浮动,那么它的祖先元素一定要有高度.
高度的盒子,才能关住浮动
清除浮动的方法2:clear:both;
- 网页制作中,高度height很少出现.为什么?因为能被内容撑高!那么也就是说,刚才我们讲解的方法1,工作中用的极少.
- clear:both; clear就是清除,both指的是左浮动,右浮动都要清除.意思就是:清除别人对我的影响.
这个方法有一个非常大的,并且致命的问题,margin失效了!
清除浮动方法3:隔墙法与内墙法
- 隔墙法 该方法通过div.cl h16这堵墙将两个父类分隔,弥补了clear:both方法中margin无效的情况,可以通过设置墙的高度来控制间隙
弊端:网页渲染后,两个分隔的父类不会有高度
- 内墙法 顾名思义,将墙修在了父类里面
清除浮动方法4:overflow:hidden;
- overflow:hidden;的本意是将超出父类的部分隐藏
清除浮动的最后总结
- 1) 加高法:
浮动的元素,只能被有高度的盒子关住。 也就是说,如果盒子内部有浮动,这个盒子有高,那么妥妥的,浮动不会互相影响。但是,工作上,我们绝对不会给所有的盒子加高度,这是因为麻烦,并且不能适应页面的快速变化。
1 <div> → 设置height 2 <p></p> 3 <p></p> 4 <p></p> 5 </div> 6 7 <div> → 设置height 8 <p></p> 9 <p></p> 10 <p></p> 11 </div>
- clear:both;法
最简单的清除浮动的方法,就是给盒子增加clear:both;表示自己的内部元素,不受其他盒子的影响。
1 <div> 2 <p></p> 3 <p></p> 4 <p></p> 5 </div> 6 7 <div> → clear:both; 8 <p></p> 9 <p></p> 10 <p></p> 11 </div>
- 3)隔墙法:
在两部分浮动元素中间,建一个墙。隔开两部分浮动,让后面的浮动元素,不去追前面的浮动元素。
墙用自己的身体当做了间隙。
1 <div> 2 <p></p> 3 <p></p> 4 <p></p> 5 </div> 6 7 <div class="cl h10"></div> 8 9 <div> 10 <p></p> 11 <p></p> 12 <p></p> 13 </div>
- 内墙法:
1 <div> 2 <p></p> 3 <p></p> 4 <p></p> 5 <div class="cl h10"></div> 6 </div> 7 8 <div> 9 <p></p> 10 <p></p> 11 <p></p> 12 </div>
- 4)overflow:hidden;
未经允许不得转载:易优模板_网站html模板-网站运营 » 浮动的清除 -- 四种方法