日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

深度css:关于浮动(float,clear)的图形化理解

發(fā)布時(shí)間:2025/3/15 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 深度css:关于浮动(float,clear)的图形化理解 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

接觸CSS以來(lái),有人說(shuō)浮動(dòng)始終給人一種神秘的感覺(jué),正因?yàn)橛辛怂囊怀刹蛔兊膖able布局開(kāi)始了漸漸被div+css取代,它是控制傳說(shuō)中文本流核心和關(guān)鍵要素,懂得控制“塊”的流動(dòng)和布局即等于控制了網(wǎng)頁(yè)的排版和布局。今天就以簡(jiǎn)單圖文形式給大家簡(jiǎn)單分享一下css浮動(dòng)原理

寫(xiě)在前面的話:

上幾期技術(shù)共享中已經(jīng)和大家講解了CSS盒子模型,接著這個(gè)話題我們繼續(xù)講解怎么對(duì)這些盒子進(jìn)行控制——浮動(dòng)。如果css中float屬性您一直不理解,網(wǎng)頁(yè)總是出現(xiàn)錯(cuò)位或者你希望它出現(xiàn)的地方他卻跑到別的地方去。那么這篇文章可以給予您一定的幫助。

本文僅僅是入門(mén)教程,權(quán)當(dāng)拋磚引玉,不當(dāng)之處請(qǐng)諒解!

本文以div元素布局為例。

教程開(kāi)始:

首先要知道,css中存在兩大類元素,行內(nèi)元素和塊級(jí)元素,行內(nèi)元素(如:<a>、<b>、<strong>等)默認(rèn)就能在一行內(nèi)共存;相對(duì)的如“div”就是塊級(jí)元素,在頁(yè)面中獨(dú)占一行,自上而下排列,也就是傳說(shuō)中的。如下圖:

?

可以看出,即使div1的寬度很小,頁(yè)面中一行可以容下div1和div2,div2也不會(huì)排在div1后邊,因?yàn)閐iv元素是獨(dú)占一行的。

注意,以上這些理論,是指“標(biāo)準(zhǔn)流”中的div。

無(wú)論多么復(fù)雜的布局,其基本出發(fā)點(diǎn)均是:“如何按設(shè)計(jì)者要求有序可控的排布div元素”。

顯然標(biāo)準(zhǔn)流并無(wú)法滿足大多數(shù)的排布需求,因?yàn)槲覀兒芏鄷r(shí)候一行內(nèi)并不僅只有一個(gè)div,我們會(huì)有兩個(gè)、三個(gè)甚至更多更甚者div里嵌套div或者其他塊塊級(jí)元素,要讓這些塊(盒子)都按需排布,這就要用到浮動(dòng)了。

?

浮動(dòng)可以理解為讓某個(gè)div元素脫離標(biāo)準(zhǔn)流,漂浮在標(biāo)準(zhǔn)流之上,而其他不受float影響的div或者其他元素仍按照標(biāo)準(zhǔn)流顯示在自己該在的位置。

例如,假設(shè)上圖中的div2浮動(dòng),那么它將脫離標(biāo)準(zhǔn)流,但div1、div3、div4仍然在標(biāo)準(zhǔn)流當(dāng)中,所以div3會(huì)自動(dòng)向上移動(dòng),占據(jù)div2的位置,重新組成一個(gè)流。如圖:

?

從圖中可以看出,由于對(duì)div2設(shè)置浮動(dòng),因此它不再屬于標(biāo)準(zhǔn)流,div3自動(dòng)上移頂替div2的位置,div1、div3、div4依次排列,成為一個(gè)新的流。又因?yàn)楦?dòng)是漂浮在標(biāo)準(zhǔn)流之上的,因此div2擋住了一部分div3,div3看起來(lái)變“矮”了。

這里div2用的是左浮動(dòng)(float:left;),可以理解為漂浮起來(lái)后靠左排列,右浮動(dòng)(float:right;)當(dāng)然就是靠右排列。這里的靠左、靠右是說(shuō)頁(yè)面(或者父div)的左、右邊緣。

如果我們把div2采用右浮動(dòng),會(huì)是如下效果:

?此時(shí)div2靠頁(yè)面右邊緣排列,不再遮擋div3,讀者可以清晰的看到上面所講的div1、div3、div4組成的流。

目前為止我們只浮動(dòng)了一個(gè)div元素,多個(gè)呢?

下面我們把div2和div3都加上左浮動(dòng),效果如圖:

?

同理,由于div2、div3浮動(dòng),它們不再屬于標(biāo)準(zhǔn)流,因此div4會(huì)自動(dòng)上移,與div1組成一個(gè)“新”標(biāo)準(zhǔn)流,而浮動(dòng)是漂浮在標(biāo)準(zhǔn)流之上,因此div2又擋住了div4。

注意,到重點(diǎn)了,當(dāng)同時(shí)對(duì)div2、div3設(shè)置浮動(dòng)之后,div3會(huì)跟隨在div2之后,大家可以發(fā)現(xiàn)一直到現(xiàn)在,div2在每個(gè)例子中都是浮動(dòng)的,但并沒(méi)有跟隨到div1之后。因此,我們可以得出一個(gè)重要結(jié)論:

假如某個(gè)div元素A是浮動(dòng)的,如果A元素上一個(gè)元素也是浮動(dòng)的,那么A元素會(huì)跟隨在上一個(gè)元素的后邊(如果一行放不下這兩個(gè)元素,那么A元素會(huì)被擠到下一行);如果A元素上一個(gè)元素是標(biāo)準(zhǔn)流中的元素,那么A的相對(duì)垂直位置不會(huì)改變,也就是說(shuō)A的頂部總是和上一個(gè)元素的底部對(duì)齊。

div的順序是HTML代碼中div的順序決定的。

靠近頁(yè)面邊緣的一端是前,遠(yuǎn)離頁(yè)面邊緣的一端是后。

?

為了幫助讀者理解,再舉幾個(gè)例子。

假如我們把div2、div3、div4都設(shè)置成浮動(dòng),效果如下:

?

根據(jù)上邊的結(jié)論,對(duì)著上面的總結(jié)理解一遍:先從div4開(kāi)始分析,它發(fā)現(xiàn)上邊的元素div3是浮動(dòng)的,所以div4會(huì)跟隨在div3之后;div3發(fā)現(xiàn)上邊的元素div2也是浮動(dòng)的,所以div3會(huì)跟隨在div2之后;而div2發(fā)現(xiàn)上邊的元素div1是標(biāo)準(zhǔn)流中的元素,因此div2的相對(duì)垂直位置不變,頂部仍然和div1元素的底部對(duì)齊。由于是左浮動(dòng),左邊靠近頁(yè)面邊緣,所以左邊是前,因此div2在最左邊。

假如把div2、div3、div4都設(shè)置成浮動(dòng),效果如下:

?

道理和左浮動(dòng)基本一樣,只不過(guò)需要注意一下前后對(duì)應(yīng)關(guān)系。由于是右浮動(dòng),因此右邊靠近頁(yè)面邊緣,所以右邊是前,因此div2在最右邊。

假如我們把div2、div4左浮動(dòng),效果圖如下:

?

依然是根據(jù)結(jié)論,div2、div4浮動(dòng),脫離了標(biāo)準(zhǔn)流,因此div3將會(huì)自動(dòng)上移,與div1組成標(biāo)準(zhǔn)流。div2發(fā)現(xiàn)上一個(gè)元素div1是標(biāo)準(zhǔn)流中的元素,因此div2相對(duì)垂直位置不變,與div1底部對(duì)齊。div4發(fā)現(xiàn)上一個(gè)元素div3是標(biāo)準(zhǔn)流中的元素,因此div4的頂部和div3的底部對(duì)齊,并且總是成立的,因?yàn)閺膱D中可以看出,div3上移后,div4也跟著上移,div4總是保證自己的頂部和上一個(gè)元素div3(標(biāo)準(zhǔn)流中的元素)的底部對(duì)齊

至此,添加浮動(dòng)已經(jīng)講解完畢了,但還有清除浮動(dòng),有上邊的基礎(chǔ)清除浮動(dòng)非常容易理解。

經(jīng)過(guò)上邊的學(xué)習(xí),可以看出:元素浮動(dòng)之前,也就是在標(biāo)準(zhǔn)流中,是豎向排列的,而浮動(dòng)之后可以理解為橫向排列。

清除浮動(dòng)可以理解為打破橫向排列。

清除浮動(dòng)的關(guān)鍵字是clear,官方定義如下:

語(yǔ)法:

clear : none | left | right | both

取值:

none : 默認(rèn)值。允許兩邊都可以有浮動(dòng)對(duì)象

left : 不允許左邊有浮動(dòng)對(duì)象

right : 不允許右邊有浮動(dòng)對(duì)象

both : 不允許有浮動(dòng)對(duì)象

定義非常容易理解,但是讀者實(shí)際使用時(shí)可能會(huì)發(fā)現(xiàn)不是這么回事。

定義沒(méi)有錯(cuò),只不過(guò)它描述的太模糊,讓我們不知所措。

根據(jù)上邊的基礎(chǔ),假如頁(yè)面中只有兩個(gè)元素div1、div2,它們都是左浮動(dòng),場(chǎng)景如下:

?

此時(shí)div1、div2都浮動(dòng),根據(jù)規(guī)則,div2會(huì)跟隨在div1后邊,但我們?nèi)匀幌M鹍iv2能排列在div1下邊,就像div1沒(méi)有浮動(dòng),div2左浮動(dòng)那樣。

這時(shí)候就要用到清除浮動(dòng)(clear),如果單純根據(jù)官方定義,大家可能會(huì)嘗試這樣寫(xiě):在div1的CSS樣式中添加clear:right;,理解為不允許div1的右邊有浮動(dòng)元素,由于div2是浮動(dòng)元素,因此會(huì)自動(dòng)下移一行來(lái)滿足規(guī)則。

其實(shí)這種理解是不正確的,這樣做沒(méi)有任何效果。看小菜定論:

對(duì)于CSS的清除浮動(dòng)(clear),一定要牢記:這個(gè)規(guī)則只能影響使用清除的元素本身,不能影響其他元素。

怎么理解呢?就拿上邊的例子來(lái)說(shuō),我們是想讓div2移動(dòng),但我們卻是在div1元素的CSS樣式中使用了清除浮動(dòng),試圖通過(guò)清除div1右邊的浮動(dòng)元素(clear:right;)來(lái)強(qiáng)迫div2下移,這是不可行的,因?yàn)檫@個(gè)清除浮動(dòng)是在div1中調(diào)用的,它只能影響div1,不能影響div2。

根據(jù)小菜定論,要想讓div2下移,就必須在div2的CSS樣式中使用浮動(dòng)。本例中div2的左邊有浮動(dòng)元素div1,因此只要在div2的CSS樣式中使用clear:left;來(lái)指定div2元素左邊不允許出現(xiàn)浮動(dòng)元素,這樣div2就被迫下移一行。

?

那么假如頁(yè)面中只有兩個(gè)元素div1、div2,它們都是右浮動(dòng)呢?讀者此時(shí)應(yīng)該已經(jīng)能自己推測(cè)場(chǎng)景,如下:

?

此時(shí)如果要讓div2下移到div1下邊,要如何做呢?

同樣根據(jù)定論,我們希望移動(dòng)的是div2,就必須在div2的CSS樣式中調(diào)用浮動(dòng),因?yàn)楦?dòng)只能影響調(diào)用它的元素。

可以看出div2的右邊有一個(gè)浮動(dòng)元素div1,那么我們可以在div2的CSS樣式中使用clear:right;來(lái)指定div2的右邊不允許出現(xiàn)浮動(dòng)元素,這樣div2就被迫下移一行,排到div1下邊。

?

至此,讀者已經(jīng)掌握了CSS+DIV浮動(dòng)定位基本原理,足以應(yīng)付常見(jiàn)的布局。

其實(shí),萬(wàn)變不離其宗,只要大家用心體會(huì),再?gòu)?fù)雜的布局都可以通過(guò)這樣的規(guī)律來(lái)搞定。

寫(xiě)在后面的話:

CSS這種語(yǔ)言常搞得大家極其混亂,尤其是瀏覽器的兼容性問(wèn)題,為什么它被歸結(jié)到前端語(yǔ)言,我想大部分原因就在于其使用時(shí)常涉及繪圖和排版的知識(shí),我們?cè)趯?shí)現(xiàn)一個(gè)網(wǎng)頁(yè)效果時(shí)更多的時(shí)候是使用css在畫(huà)圖,所以掌握css一個(gè)很重要的因素是使用者必須調(diào)動(dòng)起自己的圖形組織思維,讓html中每一個(gè)元素按效果圖規(guī)劃有序可控的排序起來(lái)。

因此使用圖文教程撇開(kāi)代碼用圖形的思路給大家講解一遍css浮動(dòng)的原理,也使大家閱讀更加輕松,跟著教程大家嘗試做一次思維的繪圖相信您的收獲不會(huì)少。

轉(zhuǎn)載于:https://www.cnblogs.com/zerow01/archive/2013/04/23/3335820.html

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

總結(jié)

以上是生活随笔為你收集整理的深度css:关于浮动(float,clear)的图形化理解的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。