首頁 > web前端 > css教學 > 主體

css之浮動

高洛峰
發布: 2016-10-09 15:43:04
原創
1352 人瀏覽過

標準文檔流

將窗體自上而下分成一行行, 並在每行中按從左到右的順序排放元素,即為文檔流.每個非浮動塊級元素都獨佔一行, 浮動元素則依規定浮在行的一端. 若當前行容不下, 則另起新行再浮動.

標準流的微觀現象

空白折疊現象

css之浮動

空白折疊現象

css之浮動

空白折疊現象

css之浮動

空白折疊現象css之浮動

空白折疊現象

空白折疊現象,圖片和表單元素可以看成是文字

高矮不齊,底邊對齊

自動換行,一行寫不下,換行寫

塊元素​​佔,不能與其他任何元素並列

可以設定寬、高,如果不設定寬度,那麼寬度將預設為父親的100%。

行內元素

與其他行內元素並排

無法設定寬、高,預設的寬度就是文字的寬度。

標籤分類

在HTML中,標籤可分為:文字層級、容器級。 🎜🎜文本級:p、span、a、b、i、u、em🎜🎜容器級:p、h系列、li、dt、dd🎜🎜CSS的分類和上面的很像,就p不一樣:🎜 🎜所有的文字級標籤,都是行內元素,除了p,p是個文字級,但是是個區塊級元素。 🎜🎜所有的容器級標籤都是區塊級元素。 🎜🎜塊級元素和行內元素的相互轉換🎜🎜塊級元素可以設定為行內元素,行內元素可以設定為塊級元素🎜
display: inline;/*块级元素转为行内元素*/
登入後複製
🎜一旦給一個p設置  display: inline; 此時這個p不能設置寬度、此時這個p不能設置寬度、此時這個p高度;那麼,這個p將立即變成行內元素。此時它和一個span無異,這個p可以和其他標籤並排了。 🎜
display: block;/*行内元素转为块级元素*/
登入後複製
🎜一旦給一個span設定 display: block; 則span變成區塊級元素。此時這個標籤,和一個p無異, 此時這個span能夠設定寬度、高度;此時這個span必須霸占一行了,別人無法和他並排;如果不設定寬度,將撐滿父親。 🎜

css之浮動

display: inline-block;/*元素既能并排,又能设置宽高*/
登入後複製

css之浮動

标准文档流无法布局,所以需要元素脱离文档流,css中一共有三种手段,使一个元素脱离标准文档流:

浮动

css之浮動

浮动的三个性质

浮动的元素脱离标准文档流

   .p1{
      float: left;
           width: 100px;
       height: 100px;
       background-color: red;
    }
   .p2{
       width: 150px;
       height: 150px;
       background-color: green;
    }我是p1我是p2
登入後複製

效果如下:p1浮动之后,脱离了标准文档流,p2就是标准文档流中的第一个盒子,所以就渲染在了页面的左上方。

css之浮動

浮动之后,一个span标签不需要转成块级元素,就能够设置宽度、高度了。所以能够证明一件事儿,就是所有标签已经不区分行内、块了。也就是说,一旦一个元素浮动了,那么将能够并排了,并且能够设置宽高了。无论它原来是个p还是个span。参考浮动的第一个图。

浮动的元素互相贴靠

    body{font-size: 60px;}
    .p1{float: left;width: 100px;height: 100px;background-color: red;}
    .p2{float: left;width: 150px;height: 150px;background-color: green;}
    .p3{float: left;width: 200px;height: 200px;background-color: blue;}123
登入後複製

css之浮動

如果有足够空间,那么p3就会靠着p2。如果没有足够的空间,那么p3会靠着p1,如果没有足够的空间靠着p1,自己去贴页面左边。 

浮动的元素有“字围”效果

css之浮動

  p{float: left;width: 320px;height: 320px;background-color: orange;}          此处省略一万字
登入後複製

p挡住了p,但是p中的文字不会被挡住,形成“字围”效果。

浮动的清除

先看看不清除浮动的效果

        Document            ul {list-style: none; }
        li { float: left;margin-left: 5px;padding: 0;}
        .p1 li {background-color: red;}
        .p2 li {background-color: green; }
                            园子            新闻            博问                                    首页            精华            候选
登入後複製

css之浮動

本想让p1和p2分成两行显示,但是结果显示在了一行,第二组中的第1个li,去贴靠第一组中的最后一个li了。看看两个p的高度,显示为0,原因就是因为p没有高度,不能给自己浮动的子元素们一个容器。

css之浮動

清除浮动方法

清除浮动方法1.给浮动的元素的祖先元素加高度

如果一个元素要浮动,那么它的祖先元素一定要有高度,有高度的盒子,才能关住浮动。只要浮动在一个有高度的盒子中,那么这个浮动就不会影响后面的浮动元素。所以就是清除浮动带来的影响了。

上面的代码,为了让p1浮动的子元素不影响p2,给p1增加 .p1{height: 50px;} 或者给p1的任何一个父级加上高度就达到了想要的结果。

css之浮動

网页制作中,高度height很少出现。因为能被内容撑高(浮动的元素不能撑高父元素),所以这种清除浮动的方法不太适用。

清除浮动方法2:clear:both; 

clear:both; 清除左右浮动,这种方法有一个非常大的问题,margin失效了。

        Document           ul{list-style: none;}
       li{float: left;margin-left: 5px;padding: 0;background-color: green;}
       .p1{margin-bottom: 100px;}/*margin失效*/
       .p2{margin-top: 100px;clear:both;}/*margin失效*/
                            园子            新闻            博问                                    首页            精华            候选
登入後複製

css之浮動

清除浮动方法3:隔墙法

外墙法

        Document           ul{list-style: none;}
       li{float: left;margin-left: 5px;padding: 0;background-color: green;}
       .p1{margin-bottom: 100px;}/*margin失效*/
       .both { clear: both;margin-top:100px; }/*margin失效*/
     .h10{height:10px;}
                            园子            新闻            博问                                        首页            精华            候选
登入後複製

margin仍然失效,但是可以给

设置高度,充当margin效果。

css之浮動

内墙法

放到p1的内部,好处是内容可以撑出父级的高了,margin也不会失效了。

        Document           ul{list-style: none;}
       li{float: left;margin-left: 5px;padding: 0;background-color: green;}
       .both { clear: both; }
       .h10{height:10px;}
                            园子            新闻            博问                                            首页            精华            候选
登入後複製

清除浮动方法4:overflow:hidden;

一个父元素不能被自己浮动的子元素撑出高度。但是只要给父级元素加上 overflow:hidden ; 父亲就能被子元素撑出高了。

IE6不支持用 overflow:hidden;来清除浮动的,解决办法是追加一条 _zoom:1;

        Document           ul{list-style: none;}
       li{float: left;margin-left: 5px;padding: 0;background-color: green;}
       .p1{overflow:hidden;}
                            园子            新闻            博问                                            首页            精华            候选
登入後複製


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!