CSS之基础知识开篇(三)

1.浮动产生负作用

  • 背景不能显示
    由于浮动产生,如果对父级设置了(CSS background背景)CSS背景颜色或CSS背景图片,而父级不能被撑开,所以导致CSS背景不能显示。
  • 边框不能撑开
    如果父级设置了CSS边框属性(css border),由于子级里使用了float属性,产生浮动,父级不能被撑开,导致边框不能随内容而被撑开。
  • margin padding设置值不能正确显示
    由于浮动导致父级子级之间设置了css padding、css margin属性的值不能正确表达。特别是上下边的padding和margin不能正确显示。

2. 清除浮动(真正的叫法叫闭合标签)

目的:为父盒子撑开高度,解决父盒子为0的问题
需要清除浮动的原因:一般都浮动了,不同div的盒子都会紧贴在一起,块级元素要并列需要浮动,但是要两个都浮动的盒子上下排列,不紧跟,并且保持第二个盒子里面的内容并排,就需要清除第二个盒子的浮动。简单地说,浮动是因为使用了float:left或float:right或两者都有而产生的浮动。

  • 方法1.为父级元素添加高度(这种方法儿子最高的高度变了,父亲的高度也要手动撑开,调成跟儿子一样大);如果父级元素box1没写高度的话没写高度,在用box2的时候,会自动贴到box1后面,所以box1要设置高度,为儿子们撑起一片天,才不会让外人入侵;
    如果一个元素要浮动,那么它的祖先元素一定要有高度。高度的盒子,才能关住浮动。
    只要浮动在一个有高度的盒子中,那么这个浮动就不会影响后面的浮动元素。所以就是清除浮动带来的影响了。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
    <title>Document</title>
    <style type="text/css">
    *{
        margin: 0;
        padding: 0;
  /*内外边距为0,元素贴边显示*/
    }
    .box1{
        width: 400px;
        /*height: 80px;为父级添加高度*/
        background-color: black;
    }
    .b1{
        float: left;
        width: 80px;
        height: 50px;
        background: green;
    }
    .b2{
        float: left;
        width: 80px;
        margin-left: 10px;
        height: 50px;
        background: orange;
    }
    .b3{
        margin-left: 10px;
        float: left;
        width: 80px;
        height: 50px;
        background: green;
    }
    .box2{
        width: 400px;
        height: 80px;
        background: red;
    }
    .b4{
        float: left;
        width: 80px;
        height: 50px;
        background: purple;
    }
    </style>
</head>
<body>
<div class="box1">
<div class="b1"></div>
<div class="b2"></div>
<div class="b3"></div>   
</div>
<div class="box2">
<div class="b4"></div>
<div class="b5"></div>
<div class="b6"></div>   
</div>   
</body>
</html>

没高度的结果:

Paste_Image.png

为父级增加高度的结果(父级的高度比儿子高,或与最大的相等):

Paste_Image.png
  • 方法2:用clear:coth(总共用的有三种放置clear:both的方法,清除左右浮动:外墙法),又称隔墙法,不能使父亲撑开高度。隔开两部分的浮动
    clear:both是指不允许元素浮动在该元素的两侧。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
    <title>Document</title>
    <style type="text/css">
    *{
        margin: 0;
        padding: 0;
    }
    .box1{
        width: 400px;
        /*height: 80px;方法1为父级添加高度*/
        background-color: black;
    }
    .b1{
        float: left;
        width: 80px;
        height: 50px;
        background: green;
    }
    .b2{
        float: left;
        width: 80px;
        margin-left: 10px;
        height: 50px;
        background: orange;
    }
    .b3{
        margin-left: 10px;
        float: left;
        width: 80px;
        height: 50px;
        background: green;
    }
    .box2{
        width: 400px;
        height: 80px;
        background: red;
    }
    .b4{
        float: left;
        width: 80px;
        height: 50px;
        background: purple;
    }
    .cb1{
        clear: both;
        /*clear: both;方法2,清除左右浮动*/
    }
    </style>
</head>
<body>
<div class="box1">
<div class="b1"></div>
<div class="b2"></div>
<div class="b3"></div>   
</div>
<div class="cb1"></div>
<!-- 在两个盒子之间再添加一个box -->
<div class="box2">
<div class="b4"></div>
<div class="b5"></div>
<div class="b6"></div>   
</div>   
</body>
</html>

在两个盒子间添加盒子显示结果:

Paste_Image.png
  • 方法3:同样用clear:both(内墙法),但是在一个盒子内在添加一个盒子(相比在之间添加盒子,这种方法能够为自动为父级的盒子添加合适的高度,该高度是子级儿子撑出的最高的高度,因为如果两个盒子父级都没有高度为0的话,就没办法用背景色修饰。因为(浮动)脱标的元素是不能把一个元素撑出高度的)-还有一种可以写在第二个盒子的div里,但是不能用margin.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
    <title>Document</title>
    <style type="text/css">
    .*{
        margin: 0;
        padding: 0;
    }
    .box1{
        width: 400px;
        /*height: 80px;为父级添加高度*/
        background-color: black;
    }
    .b1{
        float: left;
        width: 80px;
        height: 50px;
        background: green;
    }
    .b2{
        float: left;
        width: 80px;
        margin-left: 10px;
        height: 50px;
        background: orange;
    }
    .b3{
        margin-left: 10px;
        float: left;
        width: 80px;
        height: 50px;
        background: green;
    }
    .box2{
        width: 400px;
        height: 80px;
        background: red;
    }
    .b4{
        float: left;
        width: 80px;
        height: 50px;
        background: purple;
    }
    .cb1{
        clear: both;
        /*clear: both;清除浮动*/
    }
<!-- 为两个盒子添加缝隙
.h1{
        height:20px;
        background: green;
}
--> 
    </style>
</head>
<body>
<div class="box1">
<div class="b1"></div>
<div class="b2"></div>
<div class="b3"></div>   
<div class="cb1 h1"></div>
<!-- 在一个盒子之间再添加一个box -->
</div>
<div class="box2">
<!-- 还有一个方法3可以把class="cb1 h1"写在box2这里,用clear:both,但是margin会失效,不能产生缝隙。 -->
<div class="b4"></div>
<div class="b5"></div>
<div class="b6"></div>   
</div>   
</body>
</html>

显示结果:

Paste_Image.png
  • 方法四:overflow:hidden:溢出隐藏,可以把溢出边框的内容隐藏掉;
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
    <title>Document</title>
     <style type="text/css">
     div{
         width: 500px;
         height: 60px;
         color: blue;
         border: 10px solid red;
         overflow: hidden;
     }
     </style>
</head>
<body>
<div>
    <div>
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大
        你看看我有多大你看看我有多大你看看我有多大结束
    </div>
</div>
</body>
</html>

使用前:

Paste_Image.png

使用后:

Paste_Image.png

但是当遇到浮动的时候,他的效果与内墙法是一样的,能为父亲增加高度,记得是为父级的盒子添加。触发bfc模式,不用再清除浮动。但是缺点是当有超出部分会被清除掉,无法显示

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
    <title>Document</title>
    <style type="text/css">
    *{
        margin: 0;
        padding: 0;
    }
    .box1{
        width: 400px;
        /*height: 80px;为父级添加高度*/
        background-color: black;
        overflow: hidden;


    }
    .b1{
        float: left;
        width: 80px;
        height: 50px;
        background: green;
    }
    .b2{
        float: left;
        width: 80px;
        height: 50px;
        background: orange;
    }
    .b3{
        float: left;
        width: 80px;
        height: 50px;
        background: green;
    }
    .box2{
        margin-top: 10px;
        width: 400px;
        background: red;
    }
    .b4{
        float: left;
        width: 80px;
        height: 80px;
        background: purple;
    }
    /*.cb1{
        clear: both;               
        background: black;
        /*clear: both;清除浮动*/

    /*.h1{
        height:20px;
        background: green;
    }*/

    </style>
</head>
<body>
<div class="box1">
<div class="b1"></div>
<div class="b2"></div>
<div class="b3"></div>   

<!-- 在一个盒子之间再添加一个box -->
</div>
<!-- <div class="cb1 h1"></div>
 --><div class="box2">
<div class="b4"></div>
<div class="b5"></div>
<div class="b6"></div>   
</div>   
</body>
</html>

使用前:

Paste_Image.png

使用后:

Paste_Image.png
  • 方法五(压轴方法:网易;要背):
    清除浮动真正叫法叫闭合浮动;伪元素(放在浮动的父元素上形成闭合):
.clearfix:after {       <----在类名为“clearfix”的元素内最后面加入内容;
    content: ".";     <----内容为“.”就是一个英文的句号而已。也可以不写。
    display: block;   <----加入的这个元素转换为块级元素。
    clear: both;     <----清除左右两边浮动。
    visibility: hidden;      <----可见度设为隐藏。注意它和display:none;是有区别的。
仍然占据空间,只是看不到而已;
    height: 0;     <----高度为0;
    font-size:0;    <----字体大小为0;
}

整段代码就相当于在浮动元素后面跟了个宽高为0的空div,然后设定它clear:both来达到清除浮动的效果。(这个css的原理是经过使用 after伪对象,它将在应用clearfix的元素结尾添加content中的内容,也就是一个".",并且把他设置为块级元素 (display="block");高度设置为0,clear="both",然后将其内容隐藏掉(visibility="hidden").这样就会撑开此块级元素.)
之所以用它,是因为,你不必在html文件中写入大量无意义的空标签,又能清除浮动。

IE6用zoom:1.代码如下;

Paste_Image.png

.clearfix { *zoom:1;} <----这是针对于IE6的,因为IE6不支持:after伪类,这个神奇的zoom:1让IE6的元素可以清除浮动来包裹内部元素。具体意思的话,不用深究,听说微软的工程师自己都无法解释清楚。height:1%效果也是一样。
总结:
清除浮动的方法:

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

推荐阅读更多精彩内容

  • 各种纯css图标 CSS3可以实现很多漂亮的图形,我收集了32种图形,在下面列出。直接用CSS3画出这些图形,要比...
    剑残阅读 9,506评论 0 8
  • 本文是针对刚学编程的小白,都是一些基础知识,如果想了解更多深层一点的东西,欢迎移步本人博客!! 博客地址 点击跳转...
    西巴撸阅读 531评论 0 0
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,737评论 1 92
  • 当在这一个页面上实现布局和定位有几种不同的技术。使用哪种技术,很大程序上取决于内容和目标页面,因为有很多技术比别人...
    lulu_c阅读 1,047评论 0 5
  • 提到宫崎骏,很多人都会说自己最喜欢《千与千寻》,或是《龙猫》,或是《天空之城》,而我却最喜欢《侧耳倾听》。虽然很多...
    拥抱太阳的Pluto阅读 497评论 1 1