浮动布局

浮动布局:之所以要使用到浮动布局,只要是像div等块标签,在网页显示时,无论其宽的大小,都是独占一行。而在网页布局中,我们常常需要将两个或者是多个div并排放置。由于div独占一行,并排是不可能实现的。所以我们需要采用浮动布局。

在浮动布局中,有向左浮动,即所有的浮动标签都向左靠拢对齐,当一行空间不够时,后面的标签被挤到下一行。所以建议,在开发中如果在一行使用了浮动布局那么可以用一个空的div来隔开,浮动标签和后面的标签,从而避免出现覆盖的问题,空div标签的css可以这样写 clear:both; 而不需要声明高宽等属性。

浮动布局的对立面是流动布局,流动布局跟左右相邻元素关系密切,而浮动布局能够让对象脱离左右相邻元素,在包含框内向左或向右浮动显示,但是浮动元素不能脱离文档流,依然受文档流的影响。默认情况下任何元素都不具有浮动性。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"   
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">  
<head>  
    <title>这里是标题</title>  
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
    <meta name="description" content="" />  
    <meta name="keywords" content="" />  
    <script type="text/javascript">  
  
    </script>  
    <style type="text/css">  
     *{  
        margin:0px;  
      }  
      #d1{  
        width:100px;  
        height:100px;  
        float:left;  
        background:blue;  
      }  
      #d2{  
        width:200px;  
        height:200px;  
        float:left;  
        background:red;  
      }  
        
    </style>  
</head>  
<body >   
    <div id="d1"></div>  
     <div id="d2"></div> 
</body> 

先用代码说明一下什么是浮动布局。


float3.png

当浮动布局和流动布局混在一起呢?下面代码中d3是普通的流动布局。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"   
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">  
<head>  
    <title>这里是标题</title>  
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
    <meta name="description" content="" />  
    <meta name="keywords" content="" />  
    <script type="text/javascript">  
  
    </script>  
    <style type="text/css">  
     *{  
        margin:0px;  
      }  
      #d1{  
        width:100px;  
        height:100px;  
        float:left;  
        background:blue;  
      }  
       #d2{  
        width:200px;  
        height:200px;  
        float:left;  
        background:red;  
      }  
        #d3{  
        width:400px;  
        height:400px;  
        background:yellow;  
      }  
    </style>  
</head>  
<body >   
    <div id="d1"></div>  
    <div id="d2"></div>  
    <div id="d3"></div>  
</body>  
float4.png

显然d3被遮住了。以上现象原因解释:浮动使元素脱离了左右相邻元素,正常的文档流中丢失了它的位置。父元素在高度自适应的情况下,由于浮动丢失了子元素的高度,父元素就无法被撑开,所以导致父元素的背景、边框等属性无法生效,也会使后面的元素顶上来。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"   
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">  
<head>  
    <title>这里是标题</title>  
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
    <meta name="description" content="" />  
    <meta name="keywords" content="" />  
    <script type="text/javascript">  
  
    </script>  
    <style type="text/css">  
     *{  
        margin:0px;  
      }  
      #d1{  
        width:100px;  
        height:100px;  
        float:left;  
        background:blue;  
      }  
       #d2{  
        width:200px;  
        height:200px;  
        float:left;  
        background:red;  
      }  
        #d3{  
        width:400px;  
        height:400px;  
        background:yellow;  
        clear:left;
      }  
    </style>  
</head>  
<body >   
  
         <div id="d1"></div>  
     <div id="d2"></div>  
     <div id="d3"></div>  
       
</body>
float5.png

以上是浮动布局最简单最直观的认识。
以下是浮动布局特征:
一、浮动布局以块状显示,可以定义width和height属性。

<!DOCTYPE html>
<html>
<head>
    <style type="text/css">
        span{
            width: 400px;
            height: 200px;
            border: solid red 1px;
        }
        #inline img{
            width: 100px;
        }
        #float{
            float: right;
        }
    </style>
</head>
<body>
   <span id="inline">行内元素流动显示
       <img src = "mysite.jpg"/>
    </span>
    <span id="float">行内元素浮动显示</span>
</body>
</html>
floatSpan.png

第2个span元素被定义为浮动布局之后,该元素自动以块状显示,因此span元素定义的宽和高有效。而第一个span元素由于是行内元素且没有浮动显示,所以定义的宽和高无效,所看到的红色边框仅包裹在行内元素的外边。

二、浮动元素与流动元素可以混合使用,都遵循先上后下显示规则,都受到文档流的影响。但是浮动元素能够改变相邻元素的显示位置,可以向左或向右并列显示。

<!DOCTYPE html>
<html>
<head>
    <style type="text/css">
        #contain{
            width: 700px;
            height: 400px;
            border: solid green 1px;
        }
        span{
            width: 400px;
            height: 200px;
            border: solid red 1px;
        }
        #inline img{
            width: 100px;
        }
        #float{
            float: right;
        }
    </style>
</head>
<body>
    <div id="contain">
        <span id="inline">行内元素流动显示
       <img src = "mysite.jpg"/>
    </span>
    <span id="float">行内元素浮动显示</span>
    </div>
</body>
</html>
屏幕快照 2018-01-13 下午5.14.37.png

三、浮动元素仅能改变水平显示方式,不能改变垂直显示方式,依然受文档流的影响。流动元素总会以流动的形式环绕浮动元素左右显示。

<!DOCTYPE html>
<html>
<head>
</head>
<body>
    <div style="width:400px;">
        <div style="float:left; clear: both;" align="center">
            <img src="mysite.jpg" width="120" alt="" hspace="8"><br /> 图像标题
        </div>
        CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局CSS文字环绕图片布局
    </div>
</body>
</html>
pic.png

四、浮动元素可以并列显示,如果包含框宽度不够,则会错行显示。

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

推荐阅读更多精彩内容