什么是浮動(dòng)?有哪些消除浮動(dòng)的方法?

大家好,我是IT修真院鄭州分院第四期的學(xué)員王相博,一枚正直、純潔、善良的前端程序員

今天給大家分享一下,修真院官網(wǎng)CSS(職業(yè))任務(wù)1,深度思考中的知識(shí)點(diǎn)——什么是浮動(dòng)?有哪些消除浮動(dòng)的方法?

1.背景介紹

浮動(dòng)是怎么誕生的?浮動(dòng)最初設(shè)計(jì)的目的并沒那么多事兒,就只是用來實(shí)現(xiàn)文字環(huán)繞效果而已。

點(diǎn)我看文字環(huán)繞效果

但是早期的前端開發(fā)者發(fā)現(xiàn):浮動(dòng)的元素可以設(shè)置寬高并且可以內(nèi)聯(lián)排列,是介于inline和block之間的一個(gè)神奇的存在, 在inline-block出來之前,浮動(dòng)大行其道。直到inline-block出來后,浮動(dòng)也有它自己獨(dú)特的使用場景。

2.知識(shí)剖析

浮動(dòng)到底是什么? 浮動(dòng)核心就一句話:浮動(dòng)元素會(huì)脫離文檔流并向左/向右浮動(dòng),直到碰到父元素或者另一個(gè)浮動(dòng)元素。請(qǐng)默念3次!提到文檔流,那 下面我們講講什么是文檔流。

2.1 文檔流的概念

文檔流是文檔中可顯示對(duì)象在排列時(shí)所占用的位置。

將窗體自上而下分成一行行顯示,并在每行中按從左到右的順序排放元素的效果,就是文檔流直觀的表現(xiàn)。

2.2 浮動(dòng),脫離文檔流

通過使用浮動(dòng)屬性,可以使元素脫離文檔流,上浮到文檔流之上,隨后可以改變其位置的現(xiàn)象。參看下邊的圖片,浮動(dòng)的綠色塊已經(jīng)上天了,跟藍(lán)紅 兩個(gè)塊已經(jīng)不再一個(gè)層面上了。

2.3 浮動(dòng)的屬性值

浮動(dòng)的屬性值有三個(gè):float:none;float:left;float:right;

浮動(dòng)不是任意的,其還是在父元素的范圍之中,不能脫離于父元素的內(nèi)容區(qū)域。

我們回到前面那個(gè)頁面看看,浮動(dòng)元素能不能浮動(dòng)到父元素外面去

點(diǎn)我

3.常見問題及為什么要清除浮動(dòng)

如果我們不給父元素設(shè)置高度,我們知道如果它里面的元素不浮動(dòng)的話, 那么這個(gè)外層的高是會(huì)自動(dòng)被撐開的。

若浮動(dòng)元素比它的父元素還高,那么它就會(huì)溢出父元素外面,點(diǎn)我看浮動(dòng)元素溢出

當(dāng)內(nèi)層元素所有浮動(dòng)后,則影響更大:

(1)背景不能顯示

(2)邊框不能撐開

(3)高度塌陷等

我們還是回到前面那個(gè)網(wǎng)頁看看,是不是有這些影響點(diǎn)我

4.解決方案

方法1:父級(jí)div定義 height

原理:父級(jí)div手動(dòng)定義height,就解決了父級(jí)div無法自動(dòng)獲取到高度的問題。

優(yōu)點(diǎn):簡單、代碼少、容易掌握

缺點(diǎn):只適合高度固定的布局,要給出精確的高度,如果高度和父級(jí)div不一樣時(shí),會(huì)產(chǎn)生問題

建議:不推薦使用,只建議父元素高度固定的布局時(shí)使用

點(diǎn)我設(shè)置高度

方法2:

使用clear屬性:在相同的父元素中,浮動(dòng)的子元素之后添加一個(gè)空標(biāo)簽,設(shè)置樣式為:"clear:both;"標(biāo)簽可以是div,也可以是p,或者br等塊元素。

原理:left在左側(cè)不允許浮動(dòng)元素; right在右側(cè)不允許浮動(dòng)元素; both在左右兩側(cè)均不允許浮動(dòng)元素點(diǎn)我使用clear屬性

優(yōu)點(diǎn):通俗易懂,容易掌握,適合菜鳥前期使用。

缺點(diǎn):可以想象通過此方法,會(huì)添加多少無意義的空標(biāo)簽,有違結(jié)構(gòu)與表現(xiàn)的分離,一旦代碼量大的話,在后期維護(hù)中將是噩夢(mèng)。

建議:不推薦使用,但此方法是以前主要使用的一種清除浮動(dòng)方法。

方法3:對(duì)父元素設(shè)置overflow的樣式,即overflow: auto/hidden;

原理:必須定義width,在IE6中還需要觸發(fā) hasLayout ,例如 zoom:1,同時(shí)不能定義height,使用overflow:hidden時(shí),瀏覽器會(huì)自動(dòng)檢查浮動(dòng)區(qū)域的高度

優(yōu)點(diǎn):不存在結(jié)構(gòu)和語義化問題,代碼量極少

缺點(diǎn):內(nèi)容增多時(shí)候容易造成不會(huì)自動(dòng)換行導(dǎo)致內(nèi)容被隱藏掉,不能和position配合使用,無法顯示需要溢出的元素;

建議:只推薦沒有使用position或?qū)verflow:hidden理解比較深的朋友使用。

點(diǎn)我設(shè)置overflow

方法四:據(jù)說是最高大上的方法:after(注意:作用于浮動(dòng)元素的父親)

它就是利用:after和:before來在元素內(nèi)部插入兩個(gè)元素塊,從面達(dá)到清除浮動(dòng)的效果。 其實(shí)現(xiàn)原理類似于clear:both方法,只是區(qū)別在于:clear在html插入一個(gè)div.clear標(biāo)簽, 而outer利用其偽類clear:after在元素內(nèi)部增加一個(gè)類似于div.clear的效果(clearfix用在父元素上面)。下面來看看其具體的使用方法:點(diǎn)我使用clearfix

.clearfix:before, .clearfix:after {

display: table;

content: "";

}

.clearfix:after {

clear: both;

}

.clearfix {

*zoom: 1;

}

優(yōu)點(diǎn):結(jié)構(gòu)和語義化完全正確,代碼量居中。瀏覽器兼容性強(qiáng),支持好、不容易出現(xiàn)怪問題( 知乎,Apple,stackoverflow等都是使用的這種方法)

缺點(diǎn):復(fù)用方式不當(dāng)會(huì)造成代碼量增加,初學(xué)者不理解原理,要兩句代碼結(jié)合使用才能讓主流瀏覽器都支持。

建議:推薦使用,建議定義公共類,以減少CSS代碼。

5.編碼實(shí)戰(zhàn)

6.擴(kuò)展思考

問題: 大家還知道哪些清除浮動(dòng)的方法?

7.參考文獻(xiàn)

參考一:清除浮動(dòng)(clearfix)的幾種方式

參考二:學(xué)習(xí)CSS布局

參考三:css清除浮動(dòng)float的三種方法總結(jié)

參考四:CSS清除浮動(dòng)常用方法小結(jié)

8.更多討論

討論點(diǎn):float浮動(dòng)會(huì)使元素脫離文檔流,那使用position屬性的原理進(jìn)行元素的定位是不是和它是一樣使元素脫離文檔流呢?假如脫離的話,他們是不是浮動(dòng)到同一個(gè)層面上了?

PPT鏈接:地址

文本地址:地址

視頻地址:(因多次轉(zhuǎn)碼失敗,暫不上傳)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容