浮動特性
1、浮動元素有左浮動(float:left)和右浮動(float:right)兩種
2、浮動的元素會向左或向右浮動,碰到父元素邊界、其他元素才停下來
3、相鄰浮動的塊元素可以并在一行,超出父級寬度就換行
4、浮動讓行內(nèi)元素或塊元素自動轉(zhuǎn)化為行內(nèi)塊元素(此時(shí)不會有行內(nèi)塊元素間隙問題)
5、浮動元素后面沒有浮動的元素會占據(jù)浮動元素的位置,沒有浮動的元素內(nèi)的文字會避開浮動的元素,形成文字饒圖的效果
6、父元素如果沒有設(shè)置尺寸(一般是高度不設(shè)置),父元素內(nèi)整體浮動的元素?zé)o法撐開父元素,父元素需要清除浮動
7、浮動元素之間沒有垂直margin的合并
理解練習(xí)
1、兩端對齊浮動
2、請使用浮動制作圖中所示的菜單:
3、文字饒圖效果:
清除浮動
父級上增加屬性overflow:hidden
在最后一個(gè)子元素的后面加一個(gè)空的div,給它樣式屬性 clear:both(不推薦)
使用成熟的清浮動樣式類,clearfix
.clearfix:after,.clearfix:before{ content: "";display: table;} .clearfix:after{ clear:both;} .clearfix{zoom:1;}
清除浮動的使用方法:
.con2{... overflow:hidden} 或者 <div class="con2 clearfix">
理解練習(xí)
父級盒子不給高度,子集盒子浮動,父級盒子需要清除浮動
一篇文章我們把「Web前端開發(fā)進(jìn)階篇」CSS框模型講解完了,接著我們來講解下一篇文章,關(guān)于CSS定位的內(nèi)容知識,小伙伴們跟上我的節(jié)奏,動起來,Let's go!
【引言】
CSS定位思想很簡單,就是讓你定義的元素框相對于其正常位置應(yīng)該出現(xiàn)的位置,相對于父元素、另一個(gè)元素甚至是瀏覽器窗口的位置。浮動不是完全定位,不過,它也不是正常流布局。在我們切頁面的過程中,定位和浮動是經(jīng)常用,用不好,就會出現(xiàn)頁面在不同瀏覽器的兼容性問題。我會在下面的文章中詳細(xì)說明。
CSS定位
CSS有三種定位機(jī)制:普通流、浮動和絕對定位。
除非專門指定,否則所有框都在普通流中定位。也就是說,普通流中的元素的位置由元素在 (X)HTML 中的位置決定。
塊級框從上到下一個(gè)接一個(gè)地排列,框之間的垂直距離是由框的垂直外邊距計(jì)算出來。
行內(nèi)框在一行中水平布置。可以使用水平內(nèi)邊距、邊框和外邊距調(diào)整它們的間距。但是,垂直內(nèi)邊距、邊框和外邊距不影響行內(nèi)框的高度。由一行形成的水平框稱為行框(Line Box),行框的高度總是足以容納它包含的所有行內(nèi)框。不過,設(shè)置行高可以增加這個(gè)框的高度。
通過position屬性我們可以選擇4中不同類型的定位。
1、position:static
元素框正常生成。塊級元素生成一個(gè)矩形框,作為文檔流的一部分,行內(nèi)元素則會創(chuàng)建一個(gè)或多個(gè)行框,置于其父元素中。
2、position:relative
元素框偏移某個(gè)距離。元素仍保持其未定位前的形狀,它原本所占的空間仍保留。
3、position:absolute
元素框從文檔流完全刪除,并相對于其包含塊定位。包含塊可能是文檔中的另一個(gè)元素或者是初始包含塊。元素原先在正常文檔流中所占的空間會關(guān)閉,就好像元素原來不存在一樣。元素定位后生成一個(gè)塊級框,而不論原來它在正常流中生成何種類型的框。
4、position:fixed
元素框的表現(xiàn)類似于將 position 設(shè)置為 absolute,不過其包含塊是視窗本身。
提示:相對定位實(shí)際上被看作普通流定位模型的一部分,因?yàn)樵氐奈恢孟鄬τ谒谄胀髦械奈恢谩?/p>
CSS 定位屬性允許你對元素進(jìn)行定位。
position:把元素放置到一個(gè)靜態(tài)的、相對的、絕對的、或固定的位置中。
top:定義了一個(gè)定位元素的上外邊距邊界與其包含塊上邊界之間的偏移。
right:定義了定位元素右外邊距邊界與其包含塊右邊界之間的偏移。
bottom:定義了定位元素下外邊距邊界與其包含塊下邊界之間的偏移。
left:定義了定位元素左外邊距邊界與其包含塊左邊界之間的偏移。
overflow:設(shè)置當(dāng)元素的內(nèi)容溢出其區(qū)域時(shí)發(fā)生的事情。
clip:設(shè)置元素的形狀。元素被剪入這個(gè)形狀之中,然后顯示出來。
vertical-align:設(shè)置元素的垂直對齊方式。
z-index:設(shè)置元素的堆疊順序。
了解了這些屬性后,下面我們詳細(xì)的說說相對定位和絕對定位。
相對定位是一個(gè)非常容易掌握的概念。如果對一個(gè)元素進(jìn)行相對定位,它將出現(xiàn)在它所在的位置上。然后,可以通過設(shè)置垂直或水平位置,讓這個(gè)元素“相對于”它的起點(diǎn)進(jìn)行移動。
如果將 top 設(shè)置為 20px,那么框?qū)⒃谠恢庙敳肯旅?20 像素的地方。如果 left 設(shè)置為 30 像素,那么會在元素左邊創(chuàng)建 30 像素的空間,也就是將元素向右移動。
#box_relative { position: relative; left: 30px; top: 20px; }
如下圖所示:
相對定位
注意,在使用相對定位時(shí),無論是否進(jìn)行移動,元素仍然占據(jù)原來的空間。因此,移動元素會導(dǎo)致它覆蓋其它框。
絕對定位使元素的位置與文檔流無關(guān),因此不占據(jù)空間。這一點(diǎn)與相對定位不同,相對定位實(shí)際上被看作普通流定位模型的一部分,因?yàn)樵氐奈恢孟鄬τ谒谄胀髦械奈恢谩?/p>
普通流中其它元素的布局就像絕對定位的元素不存在一樣:
#box_relative { position: absolute; left: 30px; top: 20px; }
如下圖所示:
絕對定位
絕對定位的元素的位置相對于最近的已定位祖先元素,如果元素沒有已定位的祖先元素,那么它的位置相對于最初的包含塊。
對于定位的主要問題是要記住每種定位的意義。所以,現(xiàn)在讓我們復(fù)習(xí)一下學(xué)過的知識吧:相對定位是“相對于”元素在文檔中的初始位置,而絕對定位是“相對于”最近的已定位祖先元素,如果不存在已定位的祖先元素,那么“相對于”最初的包含塊。
注釋:根據(jù)用戶代理的不同,最初的包含塊可能是畫布或 HTML 元素。
提示:因?yàn)榻^對定位的框與文檔流無關(guān),所以它們可以覆蓋頁面上的其它元素。可以通過設(shè)置 z-index 屬性來控制這些框的堆放次序。
浮動的框可以向左或向右移動,直到它的外邊緣碰到包含框或另一個(gè)浮動框的邊框?yàn)橹埂?/strong>
由于浮動框不在文檔的普通流中,所以文檔的普通流中的塊框表現(xiàn)得就像浮動框不存在一樣。
請看下圖,當(dāng)把框 1 向右浮動時(shí),它脫離文檔流并且向右移動,直到它的右邊緣碰到包含框的右邊緣:
右浮動
再請看下圖,當(dāng)框 1 向左浮動時(shí),它脫離文檔流并且向左移動,直到它的左邊緣碰到包含框的左邊緣。因?yàn)樗辉偬幱谖臋n流中,所以它不占據(jù)空間,實(shí)際上覆蓋住了框 2,使框 2 從視圖中消失。
如果把所有三個(gè)框都向左移動,那么框 1 向左浮動直到碰到包含框,另外兩個(gè)框向左浮動直到碰到前一個(gè)浮動框。
左浮動
如下圖所示,如果包含框太窄,無法容納水平排列的三個(gè)浮動元素,那么其它浮動塊向下移動,直到有足夠的空間。如果浮動元素的高度不同,那么當(dāng)它們向下移動時(shí)可能被其它浮動元素“擋住”:
左浮動
通過 float 屬性實(shí)現(xiàn)元素的浮動。因此,我們可以創(chuàng)建浮動框可以使文本圍繞圖像:
文本圍繞圖像
要想阻止行框圍繞浮動框,需要對該框應(yīng)用 clear 屬性。clear 屬性的值可以是 left、right、both 或 none,它表示框的哪些邊不應(yīng)該挨著浮動框。
為了實(shí)現(xiàn)這種效果,在被清理的元素的上外邊距上添加足夠的空間,使元素的頂邊緣垂直下降到浮動框下面:
清除浮動
這是一個(gè)有用的工具,它讓周圍的元素為浮動元素留出空間。
讓我們更詳細(xì)地看看浮動和清理。假設(shè)希望讓一個(gè)圖片浮動到文本塊的左邊,并且希望這幅圖片和文本包含在另一個(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è)問題。因?yàn)楦釉孛撾x了文檔流,所以包圍圖片和文本的 div 不占據(jù)空間。
如何讓包圍元素在視覺上包圍浮動元素呢?需要在這個(gè)元素中的某個(gè)地方應(yīng)用 clear:
不幸的是出現(xiàn)了一個(gè)新的問題,由于沒有現(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)行布局而添加無意義的標(biāo)記。
不過我們還有另一種辦法,那就是對容器 div 進(jìn)行浮動:
.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>
這樣會得到我們希望的效果。不幸的是,下一個(gè)元素會受到這個(gè)浮動元素的影響。為了解決這個(gè)問題,有些人選擇對布局中的所有東西進(jìn)行浮動,然后使用適當(dāng)?shù)挠幸饬x的元素(常常是站點(diǎn)的頁腳)對這些浮動進(jìn)行清理。這有助于減少或消除不必要的標(biāo)記。
CSS定位今天就講解到這里了,下一篇講解CSS選擇器,希望大家不要放棄學(xué)習(xí)哦!
PS:
本文為‘Web前端進(jìn)階指南’原創(chuàng),手動碼字不易,小伙伴們別忘了順手點(diǎn)個(gè)贊加個(gè)關(guān)注哈,有什么不懂的下方留言評論或私信。謝謝大家哈!
*請認(rèn)真填寫需求信息,我們會在24小時(shí)內(nèi)與您取得聯(lián)系。