日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

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

接觸CSS以來,有人說浮動始終給人一種神秘的感覺,正因為有了它的一成不變的table布局開始了漸漸被div+css取代,它是控制傳說中文本流核心和關(guān)鍵要素,懂得控制“塊”的流動和布局即等于控制了網(wǎng)頁的排版和布局。今天就以簡單圖文形式給大家簡單分享一下css浮動原理

寫在前面的話:

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

本文僅僅是入門教程,權(quán)當拋磚引玉,不當之處請諒解!

本文以div元素布局為例。

教程開始:

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

?

可以看出,即使div1的寬度很小,頁面中一行可以容下div1和div2,div2也不會排在div1后邊,因為div元素是獨占一行的。

注意,以上這些理論,是指“標準流”中的div。

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

顯然標準流并無法滿足大多數(shù)的排布需求,因為我們很多時候一行內(nèi)并不僅只有一個div,我們會有兩個、三個甚至更多更甚者div里嵌套div或者其他塊塊級元素,要讓這些塊(盒子)都按需排布,這就要用到浮動了。

?

浮動可以理解為讓某個div元素脫離標準流,漂浮在標準流之上,而其他不受float影響的div或者其他元素仍按照標準流顯示在自己該在的位置。

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

?

從圖中可以看出,由于對div2設(shè)置浮動,因此它不再屬于標準流,div3自動上移頂替div2的位置,div1、div3、div4依次排列,成為一個新的流。又因為浮動是漂浮在標準流之上的,因此div2擋住了一部分div3,div3看起來變“矮”了。

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

如果我們把div2采用右浮動,會是如下效果:

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

目前為止我們只浮動了一個div元素,多個呢?

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

?

同理,由于div2、div3浮動,它們不再屬于標準流,因此div4會自動上移,與div1組成一個“新”標準流,而浮動是漂浮在標準流之上,因此div2又擋住了div4。

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

假如某個div元素A是浮動的,如果A元素上一個元素也是浮動的,那么A元素會跟隨在上一個元素的后邊(如果一行放不下這兩個元素,那么A元素會被擠到下一行);如果A元素上一個元素是標準流中的元素,那么A的相對垂直位置不會改變,也就是說A的頂部總是和上一個元素的底部對齊。

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

靠近頁面邊緣的一端是前,遠離頁面邊緣的一端是后。

?

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

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

?

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

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

?

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

假如我們把div2、div4左浮動,效果圖如下:

?

依然是根據(jù)結(jié)論,div2、div4浮動,脫離了標準流,因此div3將會自動上移,與div1組成標準流。div2發(fā)現(xiàn)上一個元素div1是標準流中的元素,因此div2相對垂直位置不變,與div1底部對齊。div4發(fā)現(xiàn)上一個元素div3是標準流中的元素,因此div4的頂部和div3的底部對齊,并且總是成立的,因為從圖中可以看出,div3上移后,div4也跟著上移,div4總是保證自己的頂部和上一個元素div3(標準流中的元素)的底部對齊

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

經(jīng)過上邊的學習,可以看出:元素浮動之前,也就是在標準流中,是豎向排列的,而浮動之后可以理解為橫向排列。

清除浮動可以理解為打破橫向排列。

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

語法:

clear : none | left | right | both

取值:

none : 默認值。允許兩邊都可以有浮動對象

left : 不允許左邊有浮動對象

right : 不允許右邊有浮動對象

both : 不允許有浮動對象

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

定義沒有錯,只不過它描述的太模糊,讓我們不知所措。

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

?

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

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

其實這種理解是不正確的,這樣做沒有任何效果。看小菜定論:

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

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

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

?

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

?

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

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

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

?

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

其實,萬變不離其宗,只要大家用心體會,再復(fù)雜的布局都可以通過這樣的規(guī)律來搞定。

寫在后面的話:

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

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

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

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

總結(jié)

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

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

主站蜘蛛池模板: 久久久久亚洲精品系列色欲 | 国产毛片欧美毛片久久久 | 国产精品一区电影 | 九色视频在线播放 | 久久www视频 | 国产精品久久久久影院 | 在线观看免费av片 | 222aaa | 1024国产视频 | 114国产精品久久免费观看 | 美女mm131爽爽爽免费动视频 | 黑人精品一区二区三区 | 好吊视频一区二区三区四区 | 欧美极品jizzhd欧美仙踪林 | 亚洲精品成人a | 国内黄色片 | 一级黄视频| 白白色在线观看 | 美女张开腿流出白浆 | 风流少妇一区二区三区91 | 亚洲免费一级 | 成人激情在线 | 国产做爰xxxⅹ高潮视频12p | 欧美激情亚洲激情 | 婷婷激情综合网 | 久久tv| 国产精品日韩欧美大师 | 朝鲜女人性猛交 | 狠狠干狠狠操视频 | 91在线视频 | 国产999 | 日本一级理论片在线大全 | 国产馆视频 | 申鹤乳液狂飙 | 亚洲av日韩av在线观看 | 久草视频观看 | 国产一级免费视频 | 尤物网站在线观看 | 国产 一二三四五六 | 超污巨黄的小短文 | www.日韩欧美 | 蜜臀av一区二区三区 | 精品动漫一区二区三区在线观看 | 少妇人妻一区 | 成人午夜在线免费观看 | 精品国产一二三 | 黄色大片在线看 | 美女又爽又黄又免费 | 亚洲字幕成人中文在线观看 | 久色福利 | 免费av观看 | 亚洲综合日韩在线 | 亚洲久草| 黄色网页在线看 | 一级视频毛片 | 欧美丰满少妇 | 91视频播放 | 亚洲高清视频一区二区 | 中文字幕丝袜诱惑 | 国产在线最新 | 狠狠干2023| sese综合| www.黄色片 | 国产吃瓜黑料一区二区 | 日本理论片| 青娱乐91 | 国产成人精品亚洲精品色欲 | 日本一级三级三级三级 | www.欧美| xxxxx色| 日日夜夜干 | 一级视频毛片 | 在线香蕉 | 日韩欧美一区二区视频 | 边啃奶头边躁狠狠躁 | 蜜臀久久精品久久久用户群体 | 无套内谢少妇高潮免费 | 欧美丰满熟妇bbbbbb百度 | 在线一区二区不卡 | jizz黄| 日韩中文字幕精品 | 一进一出好爽视频 | 国产成人免费视频网站 | 黑人巨大精品欧美一区二区免费 | 91成人精品视频 | mm1313亚洲国产精品无码试看 | 草碰在线视频 | 日本免费网站 | 日韩成人精品 | 美女爆乳18禁www久久久久久 | 日韩免费高清一区二区 | 久久久免费高清视频 | 久久视频免费在线观看 | 伊人色影院 | 国产欧美精品一区二区三区app | 两个人看的www视频免费完整版 | 日本性生活一级片 | 亚洲国产精品二区 | 日韩和欧美一区二区 |