*清浮动——2018-01-25

一、问题:

当给子元素加浮动的时候,因为其脱离文档流,导致父元素无法包住子元素。

代码:

<style>
    /* 父元素 */
        #box{
            width: 200px;
            margin: auto;
            border: 5px solid black;
        }
    /* 子元素 */
        #box1{
            width: 100px;
            height: 100px;
            background-color: blue;
            float: left;
        }
    </style>
QQ截图20180125164719.png

二、解决方法

1、给父元素指定高度。

弊端:扩展性太差

2、给父级元素加浮动(使得两个元素在同一层级上)

弊端:
1、margin失效
2、需要给每个父级都要加浮动,导致整个页面都要浮动,不可行。

3、给父级元素加 display: inline-block;

原理:display: inline-block;与float相近,只不过不需要脱离文档流,如果该父级元素还有父级,也不需要再添加display: inline-block;父级自然会撑起高度。
弊端:margin失效,可以认为是方法2的改进版。

3、空标签清浮动

原理:因为子元素脱离文档流,父元素的高度无人撑起,所以加一个空的div,撑起高度(使用clear:both;使得该div不与浮动元素在同一行,父级的高度自然就被该div拉开了)。

    <div id="clear"></div>
#clear{
            height: 0px;
            clear: both;
        }

弊端:IE6下存在一个最小高度问题,所有高度小于19px的元素高度都被当做19px来处理。

解决方法:

在clear的样式里面再加上font-size:0;但是用这个方法只能处理2px以上的高度,2px一下就无能为力了。

4、在浮动元素下加<br clear="all"/>

原理与方法3相同,不过就是把一个空的div换成了一个折行符。
弊端:不符合W3C的标准——结构层、样式层、行为层,相分离。

5、利用after伪类(标准方法)

具体方法:给浮动元素的父级加{zoom:1;} :after{content:"";display:block;clear:both}

<style>
      #box1{
            width: 100px;
            height: 100px;
            background-color: blue;
            float: left;
        }/* 浮动元素 */
      .clear{
            zoom: 1;
        }
      .clear:after{
            content: "";
            display: block;
            clear: both;
        }
<style/>
...
<body>
    <div id="box" class="clear">
        <div id="box1"></div>
    </div>
</body>
6、overflow溢出处理

具体方法:给父级元素加overflow,同时zoom:1;

#box{
            width: 200px;
            margin: auto;
            border: 5px solid black;
/*清浮动方法*/
            overflow: auto;
            zoom: 1;
        }

弊端:如果页面中有下拉列表,下拉列表会受到影响。

总结:

其他方法了解即可,第五种方法需要掌握。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,747评论 1 92
  • CSS 是什么 css(Cascading Style Sheets),层叠样式表,选择器{属性:值;属性:值}h...
    崔敏嫣阅读 1,478评论 0 5
  • 浮动 CSS允许浮动任何元素。 浮动元素 首先,会以某种方式将浮动元素从文档的正常流中删除,不过它还是会影响布局。...
    exialym阅读 1,214评论 0 6
  • relative:生成相对定位的元素,通过top,bottom,left,right的位置相对于其正常位置进行定位...
    zx9426阅读 936评论 0 2
  • 家乡小城的护城河边开了一家儿童绘本馆,在第一次踏进去之前我早已知道它的存在了。只是心里不以为然,没觉得会有多好,也...
    老圃有余阅读 690评论 0 1