整合營(yíng)銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          好程序員web前端學(xué)習(xí)路線分享CSS浮動(dòng)-清除浮動(dòng)篇

          程序員web前端學(xué)習(xí)路線分享CSS浮動(dòng)-清除浮動(dòng)篇,為什么要清除浮動(dòng)

          這里所說(shuō)的清除浮動(dòng),并不是不要浮動(dòng)了,而是清除浮動(dòng)與浮動(dòng)之間的影響。那么到底會(huì)有什么影響呢?

          1.高度塌陷

          舉個(gè)例子我們看一下。



          我們?cè)谶@里設(shè)置了div0是外容器,div1是內(nèi)部容器,div1因?yàn)樵O(shè)置了寬高是100,所以顯示的時(shí)候就是一個(gè)橙色的100*100的方塊,但是div0僅設(shè)置了背景色,因?yàn)閐iv特有的獨(dú)占一行,寬度會(huì)自動(dòng)100%,高度被內(nèi)部容器div1撐開了,撐開的高度是100像素,所有看到一個(gè)綠色高100像素,寬度100%的容器

          現(xiàn)在我們給div1設(shè)置浮動(dòng)



          這時(shí)候我們發(fā)現(xiàn)div0這個(gè)外容器沒(méi)了,看不見了。。別急,我們?cè)赿iv0里打一些字看看



          我們發(fā)現(xiàn)aaa這些文字出來(lái)了,環(huán)繞在橙色方塊周圍了,這個(gè)原因在浮動(dòng)中我們已經(jīng)講解了,而且我們也發(fā)現(xiàn)綠色的容器也出來(lái)了,但是它的高度僅僅是文字的行高。這就說(shuō)明,內(nèi)部的橙色塊設(shè)置浮動(dòng)后,它的父級(jí)容器綠色塊就不知道橙色容器的高度了,因此綠色容器的高度變成了0,寫入文字后,綠色容器重新被撐開高度才可以看到。我們把這種情況稱為高度塌陷

          我們其實(shí)是希望一個(gè)容器中的內(nèi)容不斷的撐開容器的高度,這樣我們后續(xù)的內(nèi)容就可以緊貼在上面了,而網(wǎng)頁(yè)中的內(nèi)容并不是都是靜態(tài)的,很多都需要每天更新,更新的內(nèi)容多少,圖片高度,都不相同。那么后面的東西想要緊貼上面的內(nèi)容,上面內(nèi)容的高度就不能設(shè)置一個(gè)固定數(shù)值,否則很多數(shù)據(jù)的時(shí)候放不下。如果不設(shè)置高度,一旦設(shè)置浮動(dòng)后,就會(huì)出現(xiàn)高度塌陷。丟失了高度后,頁(yè)面后續(xù)的內(nèi)容就會(huì)插在上面內(nèi)容的底部,頁(yè)面就會(huì)錯(cuò)亂,因此我們就需要做清除浮動(dòng)來(lái)解決這個(gè)問(wèn)題,最終做到即使使用浮動(dòng),外容器也會(huì)因?yàn)閮?nèi)容的多少自動(dòng)撐開高度,不會(huì)高度塌陷。

          margin padding設(shè)置值不能正確顯示

          2.Margin和padding屬性值不正確

          由于浮動(dòng)導(dǎo)致父級(jí)子級(jí)之間設(shè)置了css padding、css margin屬性的值不能正確表達(dá)。特別是上下邊的padding和margin不能正確顯示。

          要來(lái)解決這個(gè)問(wèn)題,我們就必須來(lái)認(rèn)識(shí)一下BFC

          什么是BFC

          要來(lái)理解BFC,先介紹一下Box和Formatting Context

          Box 是 CSS 布局的對(duì)象和基本單位, 簡(jiǎn)單來(lái)說(shuō)頁(yè)面就是由Box組成,元素的類型和 display 屬性,決定了這個(gè) Box 的類型。 不同類型的 Box, 會(huì)參與不同的 Formatting Context(一個(gè)決定如何渲染文檔的容器),因此Box內(nèi)的元素會(huì)以不同的方式渲染。

          1、block-level box:display 屬性為 block, list-item, table 的元素,會(huì)生成 block-level box。并且參與 block formatting context;

          2、inline-level box:display 屬性為 inline, inline-block, inline-table 的元素,會(huì)生成 inline-level box。并且參與 inline formatting context;

          3、run-in box: css3 中才有, 這兒先不講了。

          Formatting context 是 W3C CSS2.1 規(guī)范中的一個(gè)概念。它是頁(yè)面中的一塊渲染區(qū)域,并且有一套渲染規(guī)則,它決定了其子元素將如何定位,以及和其他元素的關(guān)系和相互作用。最常見的 Formatting context 有 Block fomatting context (簡(jiǎn)稱BFC)和 Inline formatting context (簡(jiǎn)稱IFC)。

          BFC(Block formatting context)直譯為"塊級(jí)格式化上下文"。它是一個(gè)獨(dú)立的渲染區(qū)域,只有Block-level box參與, 它規(guī)定了內(nèi)部的Block-level Box如何布局,并且與這個(gè)區(qū)域外部毫不相干。

          BFC布局規(guī)則:

          (1)內(nèi)部的Box會(huì)在垂直方向,一個(gè)接一個(gè)地放置。

          (2)Box垂直方向的距離由margin決定。屬于同一個(gè)BFC的兩個(gè)相鄰Box的margin會(huì)發(fā)生重疊

          (3)每個(gè)元素的margin box的左邊, 與包含塊border box的左邊相接觸(對(duì)于從左往右的格式化,否則相反)。即使存在浮動(dòng)也是如此。

          (4)BFC的區(qū)域不會(huì)與float box重疊。

          (5)BFC就是頁(yè)面上的一個(gè)隔離的獨(dú)立容器,容器里面的子元素不會(huì)影響到外面的元素。反之也如此。

          (6)計(jì)算BFC的高度時(shí),浮動(dòng)元素也參與計(jì)算

          瞧,最后一條就是我們需要利用的了,我們只需要利用BFC就可以解決浮動(dòng)后外容器高度塌陷的問(wèn)題

          如何生成BFC

          1. 根元素是BFC模式

          這種不能考慮,因?yàn)槎疾皇歉?/p>

          2. 設(shè)置高度

          顯然也是不可以的。

          3. float屬性不為none

          本來(lái)就要設(shè)置浮動(dòng)的。所以也不考慮

          4. position為absolute或fixed

          這樣設(shè)置后,就失去浮動(dòng)的意義了。因此也不使用

          5. display為inline-block, table-cell, table-caption, flex, inline-flex

          雖然可以開啟,但是導(dǎo)致父元素原有寬度丟失

          6. overflow不為visible

          這種方法副作用比較小,但是還是有問(wèn)題的。比如overflow設(shè)置為hidden,這個(gè)不行,內(nèi)容的高度是撐開的寬度也不能確定。設(shè)置為scroll,會(huì)出現(xiàn)右邊和下邊的滾動(dòng)條寬度

          設(shè)置為auto最合適,不過(guò),如果里面的內(nèi)容使用了定位,并且超出去就會(huì)出現(xiàn)滾動(dòng)條。所以只能保證內(nèi)容不能有定位。

          Clear:both

          清除:兩者間,顧名思義就是清除浮動(dòng)



          我們看到如果要使用clear:both,就需要給高度塌陷的容器里面最后追加一個(gè)div,并且給這個(gè)div設(shè)置為clear:both,我們發(fā)現(xiàn)這種使用方法比較麻煩,每次設(shè)置都需要最后增加div。

          因此我們做了一個(gè)修改

          <!DOCTYPE html>

          一篇文章我們把「Web前端開發(fā)進(jìn)階篇」CSS框模型講解完了,接著我們來(lái)講解下一篇文章,關(guān)于CSS定位的內(nèi)容知識(shí),小伙伴們跟上我的節(jié)奏,動(dòng)起來(lái),Let's go!

          【引言】

          CSS定位思想很簡(jiǎn)單,就是讓你定義的元素框相對(duì)于其正常位置應(yīng)該出現(xiàn)的位置,相對(duì)于父元素、另一個(gè)元素甚至是瀏覽器窗口的位置。浮動(dòng)不是完全定位,不過(guò),它也不是正常流布局。在我們切頁(yè)面的過(guò)程中,定位和浮動(dòng)是經(jīng)常用,用不好,就會(huì)出現(xiàn)頁(yè)面在不同瀏覽器的兼容性問(wèn)題。我會(huì)在下面的文章中詳細(xì)說(shuō)明。

          CSS定位

          CSS定位機(jī)制

          CSS有三種定位機(jī)制:普通流、浮動(dòng)和絕對(duì)定位。

          除非專門指定,否則所有框都在普通流中定位。也就是說(shuō),普通流中的元素的位置由元素在 (X)HTML 中的位置決定。

          塊級(jí)框從上到下一個(gè)接一個(gè)地排列,框之間的垂直距離是由框的垂直外邊距計(jì)算出來(lái)。

          行內(nèi)框在一行中水平布置??梢允褂盟絻?nèi)邊距、邊框和外邊距調(diào)整它們的間距。但是,垂直內(nèi)邊距、邊框和外邊距不影響行內(nèi)框的高度。由一行形成的水平框稱為行框(Line Box),行框的高度總是足以容納它包含的所有行內(nèi)框。不過(guò),設(shè)置行高可以增加這個(gè)框的高度。

          CSS position屬性

          通過(guò)position屬性我們可以選擇4中不同類型的定位。

          1、position:static

          元素框正常生成。塊級(jí)元素生成一個(gè)矩形框,作為文檔流的一部分,行內(nèi)元素則會(huì)創(chuàng)建一個(gè)或多個(gè)行框,置于其父元素中。

          2、position:relative

          元素框偏移某個(gè)距離。元素仍保持其未定位前的形狀,它原本所占的空間仍保留。

          3、position:absolute

          元素框從文檔流完全刪除,并相對(duì)于其包含塊定位。包含塊可能是文檔中的另一個(gè)元素或者是初始包含塊。元素原先在正常文檔流中所占的空間會(huì)關(guān)閉,就好像元素原來(lái)不存在一樣。元素定位后生成一個(gè)塊級(jí)框,而不論原來(lái)它在正常流中生成何種類型的框。

          4、position:fixed

          元素框的表現(xiàn)類似于將 position 設(shè)置為 absolute,不過(guò)其包含塊是視窗本身。

          提示:相對(duì)定位實(shí)際上被看作普通流定位模型的一部分,因?yàn)樵氐奈恢孟鄬?duì)于它在普通流中的位置。

          CSS定位屬性

          CSS 定位屬性允許你對(duì)元素進(jìn)行定位。

          position:把元素放置到一個(gè)靜態(tài)的、相對(duì)的、絕對(duì)的、或固定的位置中。

          top:定義了一個(gè)定位元素的上外邊距邊界與其包含塊上邊界之間的偏移。

          right:定義了定位元素右外邊距邊界與其包含塊右邊界之間的偏移。

          bottom:定義了定位元素下外邊距邊界與其包含塊下邊界之間的偏移。

          left:定義了定位元素左外邊距邊界與其包含塊左邊界之間的偏移。

          overflow:設(shè)置當(dāng)元素的內(nèi)容溢出其區(qū)域時(shí)發(fā)生的事情。

          clip:設(shè)置元素的形狀。元素被剪入這個(gè)形狀之中,然后顯示出來(lái)。

          vertical-align:設(shè)置元素的垂直對(duì)齊方式。

          z-index:設(shè)置元素的堆疊順序。

          了解了這些屬性后,下面我們?cè)敿?xì)的說(shuō)說(shuō)相對(duì)定位和絕對(duì)定位。

          CSS相對(duì)定位

          相對(duì)定位是一個(gè)非常容易掌握的概念。如果對(duì)一個(gè)元素進(jìn)行相對(duì)定位,它將出現(xiàn)在它所在的位置上。然后,可以通過(guò)設(shè)置垂直或水平位置,讓這個(gè)元素“相對(duì)于”它的起點(diǎn)進(jìn)行移動(dòng)。

          如果將 top 設(shè)置為 20px,那么框?qū)⒃谠恢庙敳肯旅?20 像素的地方。如果 left 設(shè)置為 30 像素,那么會(huì)在元素左邊創(chuàng)建 30 像素的空間,也就是將元素向右移動(dòng)。

          #box_relative {
           position: relative;
           left: 30px;
           top: 20px;
          }

          如下圖所示:

          相對(duì)定位

          注意,在使用相對(duì)定位時(shí),無(wú)論是否進(jìn)行移動(dòng),元素仍然占據(jù)原來(lái)的空間。因此,移動(dòng)元素會(huì)導(dǎo)致它覆蓋其它框。

          CSS絕對(duì)定位

          絕對(duì)定位使元素的位置與文檔流無(wú)關(guān),因此不占據(jù)空間。這一點(diǎn)與相對(duì)定位不同,相對(duì)定位實(shí)際上被看作普通流定位模型的一部分,因?yàn)樵氐奈恢孟鄬?duì)于它在普通流中的位置。

          普通流中其它元素的布局就像絕對(duì)定位的元素不存在一樣:

          #box_relative {
           position: absolute;
           left: 30px;
           top: 20px;
          }

          如下圖所示:

          絕對(duì)定位

          絕對(duì)定位的元素的位置相對(duì)于最近的已定位祖先元素,如果元素沒(méi)有已定位的祖先元素,那么它的位置相對(duì)于最初的包含塊。

          對(duì)于定位的主要問(wèn)題是要記住每種定位的意義。所以,現(xiàn)在讓我們復(fù)習(xí)一下學(xué)過(guò)的知識(shí)吧:相對(duì)定位是“相對(duì)于”元素在文檔中的初始位置,而絕對(duì)定位是“相對(duì)于”最近的已定位祖先元素,如果不存在已定位的祖先元素,那么“相對(duì)于”最初的包含塊。

          注釋:根據(jù)用戶代理的不同,最初的包含塊可能是畫布或 HTML 元素。

          提示:因?yàn)榻^對(duì)定位的框與文檔流無(wú)關(guān),所以它們可以覆蓋頁(yè)面上的其它元素??梢酝ㄟ^(guò)設(shè)置 z-index 屬性來(lái)控制這些框的堆放次序。

          CSS浮動(dòng)

          浮動(dòng)的框可以向左或向右移動(dòng),直到它的外邊緣碰到包含框或另一個(gè)浮動(dòng)框的邊框?yàn)橹埂?/strong>

          由于浮動(dòng)框不在文檔的普通流中,所以文檔的普通流中的塊框表現(xiàn)得就像浮動(dòng)框不存在一樣。

          請(qǐng)看下圖,當(dāng)把框 1 向右浮動(dòng)時(shí),它脫離文檔流并且向右移動(dòng),直到它的右邊緣碰到包含框的右邊緣:

          右浮動(dòng)

          再請(qǐng)看下圖,當(dāng)框 1 向左浮動(dòng)時(shí),它脫離文檔流并且向左移動(dòng),直到它的左邊緣碰到包含框的左邊緣。因?yàn)樗辉偬幱谖臋n流中,所以它不占據(jù)空間,實(shí)際上覆蓋住了框 2,使框 2 從視圖中消失。

          如果把所有三個(gè)框都向左移動(dòng),那么框 1 向左浮動(dòng)直到碰到包含框,另外兩個(gè)框向左浮動(dòng)直到碰到前一個(gè)浮動(dòng)框。

          左浮動(dòng)

          如下圖所示,如果包含框太窄,無(wú)法容納水平排列的三個(gè)浮動(dòng)元素,那么其它浮動(dòng)塊向下移動(dòng),直到有足夠的空間。如果浮動(dòng)元素的高度不同,那么當(dāng)它們向下移動(dòng)時(shí)可能被其它浮動(dòng)元素“擋住”:

          左浮動(dòng)

          CSS float 屬性

          通過(guò) float 屬性實(shí)現(xiàn)元素的浮動(dòng)。因此,我們可以創(chuàng)建浮動(dòng)框可以使文本圍繞圖像:

          文本圍繞圖像

          要想阻止行框圍繞浮動(dòng)框,需要對(duì)該框應(yīng)用 clear 屬性。clear 屬性的值可以是 left、right、both 或 none,它表示框的哪些邊不應(yīng)該挨著浮動(dòng)框。

          為了實(shí)現(xiàn)這種效果,在被清理的元素的上外邊距上添加足夠的空間,使元素的頂邊緣垂直下降到浮動(dòng)框下面:

          清除浮動(dòng)

          這是一個(gè)有用的工具,它讓周圍的元素為浮動(dòng)元素留出空間。

          讓我們更詳細(xì)地看看浮動(dòng)和清理。假設(shè)希望讓一個(gè)圖片浮動(dòng)到文本塊的左邊,并且希望這幅圖片和文本包含在另一個(gè)具有背景顏色和邊框的元素中。您可能編寫下面的代碼:

          .news {
           background-color: gray;
           border: solid 1px black;
           }
          
          .news img {
           float: left;
           }
          
          .news p {
           float: right;
           }
          
          <div class="news">
          <img src="news-pic.jpg" />
          <p>some text</p>
          </div>

          這種情況下,出現(xiàn)了一個(gè)問(wèn)題。因?yàn)楦?dòng)元素脫離了文檔流,所以包圍圖片和文本的 div 不占據(jù)空間。

          如何讓包圍元素在視覺(jué)上包圍浮動(dòng)元素呢?需要在這個(gè)元素中的某個(gè)地方應(yīng)用 clear:

          不幸的是出現(xiàn)了一個(gè)新的問(wèn)題,由于沒(méi)有現(xiàn)有的元素可以應(yīng)用清理,所以我們只能添加一個(gè)空元素并且清理它。

          .news {
           background-color: gray;
           border: solid 1px black;
           }
          
          .news img {
           float: left;
           }
          
          .news p {
           float: right;
           }
          
          .clear {
           clear: both;
           }
          
          <div class="news">
          <img src="news-pic.jpg" />
          <p>some text</p>
          <div class="clear"></div>
          </div>

          這樣可以實(shí)現(xiàn)我們希望的效果,但是需要添加多余的代碼。常常有元素可以應(yīng)用 clear,但是有時(shí)候不得不為了進(jìn)行布局而添加無(wú)意義的標(biāo)記。

          不過(guò)我們還有另一種辦法,那就是對(duì)容器 div 進(jìn)行浮動(dòng):

          .news {
           background-color: gray;
           border: solid 1px black;
           float: left;
           }
          
          .news img {
           float: left;
           }
          
          .news p {
           float: right;
           }
          
          <div class="news">
          <img src="news-pic.jpg" />
          <p>some text</p>
          </div>

          這樣會(huì)得到我們希望的效果。不幸的是,下一個(gè)元素會(huì)受到這個(gè)浮動(dòng)元素的影響。為了解決這個(gè)問(wèn)題,有些人選擇對(duì)布局中的所有東西進(jìn)行浮動(dòng),然后使用適當(dāng)?shù)挠幸饬x的元素(常常是站點(diǎn)的頁(yè)腳)對(duì)這些浮動(dòng)進(jìn)行清理。這有助于減少或消除不必要的標(biāo)記。


          CSS定位今天就講解到這里了,下一篇講解CSS選擇器,希望大家不要放棄學(xué)習(xí)哦!

          PS:

          本文為‘Web前端進(jìn)階指南’原創(chuàng),手動(dòng)碼字不易,小伙伴們別忘了順手點(diǎn)個(gè)贊加個(gè)關(guān)注哈,有什么不懂的下方留言評(píng)論或私信。謝謝大家哈!

          、浮動(dòng)

          本章目標(biāo):

          • 會(huì)使用display屬性排版網(wǎng)頁(yè)元素
          • 會(huì)使用float屬性排版網(wǎng)頁(yè)元素
          • 會(huì)使用float屬性創(chuàng)建橫向多列布局
          • 會(huì)使用四種防止父級(jí)邊框塌陷的清除浮動(dòng)的方法

          4.1、標(biāo)準(zhǔn)文檔流

          標(biāo)準(zhǔn)文檔流:指元素根據(jù)塊元素或行內(nèi)元素的特性按從上到下,從左到右的方式自然排列。這也是元素默認(rèn)的排列方式

          標(biāo)準(zhǔn)文檔流組成

          • 塊級(jí)元素(block) <h1>…<h6>、<p>、<div>、列表
          • 內(nèi)聯(lián)元素(inline) <span>、<a>、<img/>、<strong>... 內(nèi)聯(lián)標(biāo)簽可以包含于塊級(jí)標(biāo)簽中,成為它的子元素,而反過(guò)來(lái)則不成立

          4.2、display

          display屬性

          在這里插入圖片描述


          主站蜘蛛池模板: 中文字幕一区二区三区人妻少妇| 日韩精品一区二区三区在线观看l| 亚洲日韩一区二区一无码| 国产精品综合一区二区三区| 在线精品视频一区二区| 国产激情一区二区三区小说| 国产精品一区12p| 免费萌白酱国产一区二区| 国产美女在线一区二区三区| 国产成人av一区二区三区不卡 | 国产精品一区二区久久| 精品国产福利在线观看一区| 人妻少妇精品一区二区三区| 亚洲国产AV一区二区三区四区 | 天堂一区人妻无码| 久久一区二区三区99| 日韩精品电影一区| 日本一区频道在线视频| 亚洲电影一区二区三区| 久久一区二区三区免费| 精品国产一区二区三区免费看| 无码av免费一区二区三区| 精品国产不卡一区二区三区| 日韩精品无码Av一区二区| 午夜爽爽性刺激一区二区视频| 人妻AV中文字幕一区二区三区| 中文字幕精品一区| 麻豆视频一区二区三区| 国产一区在线电影| 相泽南亚洲一区二区在线播放| 亚洲AV噜噜一区二区三区| 人妻无码一区二区不卡无码av| 日韩精品无码一区二区中文字幕| 精品一区二区三区东京热| 亚洲AV无码一区二区三区在线| 亚洲午夜一区二区电影院| 91在线看片一区国产| 亚洲av无码一区二区三区在线播放| 99精品国产高清一区二区| 大伊香蕉精品一区视频在线 | 美女福利视频一区|