<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      經驗分享:CSS浮動(float,clear)通俗講解

             很早以前就接觸過CSS,但對于浮動始終非常迷惑,可能是自身理解能力差,也可能是沒能遇到一篇通俗的教程。

             前些天小菜終于搞懂了浮動的基本原理,迫不及待的分享給大家。

            

      寫在前面的話:

             由于CSS內容比較多,小菜沒有精力從頭到尾講一遍,只能有針對性的講解。

             如果讀者理解CSS盒子模型,但對于浮動不理解,那么這篇文章可以幫助你。

             小菜水平有限,本文僅僅是入門教程,不當之處請諒解!

             本文以div元素布局為例。

       

      教程開始:

       

             首先要知道,div是塊級元素,在頁面中獨占一行,自上而下排列,也就是傳說中的。如下圖:

       

       

       

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

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

             小菜認為,無論多么復雜的布局,其基本出發(fā)點均是:“如何在一行顯示多個div元素”。

             顯然標準流已經無法滿足需求,這就要用到浮動。      

             浮動可以理解為讓某個div元素脫離標準流,漂浮在標準流之上,和標準流不是一個層次。

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

       

       

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

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

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

       

       

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

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

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

       

       

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

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

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

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

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

       

       

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

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

       

       

       

             根據上邊的結論,跟著小菜理解一遍:先從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都設置成浮動,效果如下:

       

       

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

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

       

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

             至此,恭喜讀者已經掌握了添加浮動,但還有清除浮動,有上邊的基礎清除浮動非常容易理解。

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

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

             清除浮動的關鍵字是clear,官方定義如下:

       

             語法:

             clear : none | left | right | both

             取值:

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

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

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

             both  :  不允許有浮動對象

       

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

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

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

           此時div1、div2都浮動,根據規(guī)則,div2會跟隨在div1后邊,但我們仍然希望div2能排列在div1下邊,就像div1沒有浮動,div2左浮動那樣。

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

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

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

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

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

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

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

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

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

       

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

             其實,萬變不離其宗,只要讀者用心體會,再復雜的布局都可以通過小菜總結的規(guī)律搞定。

       

      寫在后面的話:

       

             必須嚴正聲明,CSS這塊極其混亂,尤其是瀏覽器的兼容性問題,小菜水平有限,本文很可能有不當之處,望讀者見諒。

             其實真不想寫這么長的文章,可為了讀者能夠理解,總是不由自主的想多舉些例子。

             為了減輕讀者心理壓力,本文沒有任何CSS、HTML代碼,因為現(xiàn)在很多教程上來就是一大堆CSS代碼,看到就煩,別說細讀了。

             最后預祝讀者閱讀愉快,開心掌握知識。

       

       

      posted @ 2013-03-27 01:01  楊元  閱讀(108694)  評論(216)    收藏  舉報
      主站蜘蛛池模板: 国产精品任我爽爆在线播放6080| 亚洲a人片在线观看网址| 亚洲乳大丰满中文字幕| 又黄又爽又色视频免费| 精品国产一区二区三区av色诱| 国产亚洲无线码一区二区| 精品无码三级在线观看视频| 国产 一区二区三区视频| 青青草一区二区免费精品| 热久久美女精品天天吊色| 又爽又黄又无遮挡的激情视频| 亚洲va中文字幕无码久久不卡| 天天做日日做天天添天天欢公交车| 久久国产自偷自偷免费一区| 永久免费无码av在线网站| 欧美成人精品一级在线观看| 丰满人妻熟妇乱精品视频| 国产精品午夜福利合集| 国产成人高清在线观看视频 | 中文字幕人妻精品在线| 中文字幕第一页国产| 亚洲一区二区三区| 亚洲女同在线播放一区二区| 久久国产精品福利一区二区三区| 亚洲大老师中文字幕久热| 国内精品自线在拍| 好紧好滑好湿好爽免费视频| 精品久久精品午夜精品久久 | 亚洲国产精品一区二区第一页| 国产69精品久久久久人妻刘玥| 精品亚洲男人一区二区三区| 无遮无挡爽爽免费视频| 亚洲国产欧美一区二区好看电影| 91色老久久精品偷偷性色| 人妻在线中文字幕| 午夜大尺度福利视频一区| 亚洲天堂在线观看完整版| 国产精品一码在线播放| 亚洲综合国产伊人五月婷| 午夜成人精品福利网站在线观看| 乱人伦人妻系列|