css 相對(duì)定位 絕對(duì)定位 浮動(dòng) 分析

CSS 相對(duì)定位
相對(duì)定位是一個(gè)非常容易掌握的概念。如果對(duì)一個(gè)元素進(jìn)行相對(duì)定位,它將出現(xiàn)在它所在的位置上。然后,可以通過(guò)設(shè)置垂直或水平位置,讓這個(gè)元素“相對(duì)于”它的起點(diǎn)進(jìn)行移動(dòng)。
如果將 top 設(shè)置為 20px,那么框?qū)⒃谠恢庙敳肯旅?20 像素的地方。如果 left 設(shè)置為 30 像素,那么會(huì)在元素左邊創(chuàng)建 30 像素的空間,也就是將元素向右移動(dòng)。
#box_relative { position: relative; left: 30px; top: 20px; }
如下圖所示:

注意,在使用相對(duì)定位時(shí),無(wú)論是否進(jìn)行移動(dòng),元素仍然占據(jù)原來(lái)的空間。因此,移動(dòng)元素會(huì)導(dǎo)致它覆蓋其它框。
那么我們就會(huì)想了怎么讓框三把框二覆蓋呢,很自然的想到把框3的z-index設(shè)為一個(gè)優(yōu)先級(jí)高的值如100,但是這樣并不能得到我們想要的結(jié)果,必須把框2的z-index設(shè)為優(yōu)先級(jí)低的如-1,
我猜想是因?yàn)榭?已經(jīng)脫離了文檔流,所以只設(shè)置框3的z-index對(duì)框2起不到作用,所以只能對(duì)框2操作了。大家也可以去試試代碼如下在ie7下通過(guò):
<html>
<head runat="server">
<title>Untitled Page</title>
<style type="text/css">
span
{
background-color: Red;
width: 30px;
height: 30px;
}
#box_relative
{
position: relative;
left: 10px;
top: 10px; background-color: gray;z-index:-1;
}
</style>
</head>
<body>
<span></span><span id="box_relative"></span><span style="z-index:30"></span>
</body>
</html>
CSS 絕對(duì)定位
絕對(duì)定位使元素的位置與文檔流無(wú)關(guān),因此不占據(jù)空間。這一點(diǎn)與相對(duì)定位不同,相對(duì)定位實(shí)際上被看作普通流定位模型的一部分,因?yàn)樵氐奈恢孟鄬?duì)于它在普通流中的位置。
普通流中其它元素的布局就像絕對(duì)定位的元素不存在一樣:
#box_relative { position: absolute; left: 30px; top: 20px; }
如下圖所示:
絕對(duì)定位的元素的位置相對(duì)于最近的已定位祖先元素,如果元素沒(méi)有已定位的祖先元素,那么它的位置相對(duì)于最初的包含塊。
對(duì)于定位的主要問(wèn)題是要記住每種定位的意義。所以,現(xiàn)在讓我們復(fù)習(xí)一下學(xué)過(guò)的知識(shí)吧:相對(duì)定位是“相對(duì)于”元素在文檔中的初始位置,而絕對(duì)定位是“相對(duì)于”最近的已定位祖先元素,如果不存在已定位的祖先元素,那么“相對(duì)于”最初的包含塊。
注釋?zhuān)?/span>根據(jù)用戶(hù)代理的不同,最初的包含塊可能是畫(huà)布或 HTML 元素。
提示:因?yàn)榻^對(duì)定位的框與文檔流無(wú)關(guān),所以它們可以覆蓋頁(yè)面上的其它元素??梢酝ㄟ^(guò)設(shè)置 z-index 屬性來(lái)控制這些框的堆放次序。
同樣的道路如果想讓框1,3在2之上的話也需要在框2上設(shè)置z-index,而且如果只在框1,3上設(shè)置的話無(wú)效。大家也可以去試試代碼如下在ie7下通過(guò):
<html>
<head runat="server">
<title>Untitled Page</title>
<style type="text/css">
span
{
background-color: Red;
width: 30px;
height: 30px;
}
#box_relative
{
position: absolute;
left: 20px;
top: 20px; background-color: gray;
}
</style>
</head>
<body>
<span style="z-index:30"></span><span id="box_relative"></span><span style="z-index:30"></span>
</body>
</html>
CSS 浮動(dòng)
請(qǐng)看下圖,當(dāng)把框 1 向右浮動(dòng)時(shí),它脫離文檔流并且向右移動(dòng),直到它的右邊緣碰到包含框的右邊緣:

再請(qǐng)看下圖,當(dāng)框 1 向左浮動(dòng)時(shí),它脫離文檔流并且向左移動(dòng),直到它的左邊緣碰到包含框的左邊緣。因?yàn)樗辉偬幱谖臋n流中,所以它不占據(jù)空間,實(shí)際上覆蓋住了框 2,使框 2 從視圖中消失。
如果把所有三個(gè)框都向左移動(dòng),那么框 1 向左浮動(dòng)直到碰到包含框,另外兩個(gè)框向左浮動(dòng)直到碰到前一個(gè)浮動(dòng)框。

如下圖所示,如果包含框太窄,無(wú)法容納水平排列的三個(gè)浮動(dòng)元素,那么其它浮動(dòng)塊向下移動(dòng),直到有足夠的空間。如果浮動(dòng)元素的高度不同,那么當(dāng)它們向下移動(dòng)時(shí)可能被其它浮動(dòng)元素“卡住”:

CSS float 屬性
在 CSS 中,我們通過(guò) float 屬性實(shí)現(xiàn)元素的浮動(dòng)。
如需更多有關(guān) float 屬性的知識(shí),請(qǐng)?jiān)L問(wèn)參考手冊(cè):CSS float 屬性。
行框和清理
浮動(dòng)框旁邊的行框被縮短,從而給浮動(dòng)框留出空間,行框圍繞浮動(dòng)框。
因此,創(chuàng)建浮動(dòng)框可以使文本圍繞圖像:

要想阻止行框圍繞浮動(dòng)框,需要對(duì)該框應(yīng)用 clear 屬性。clear 屬性的值可以是 left、right、both 或 none,它表示框的哪些邊不應(yīng)該挨著浮動(dòng)框。
為了實(shí)現(xiàn)這種效果,在被清理的元素的上外邊距上添加足夠的空間,使元素的頂邊緣垂直下降到浮動(dòng)框下面:

這是一個(gè)有用的工具,它讓周?chē)脑貫楦?dòng)元素留出空間。
讓我們更詳細(xì)地看看浮動(dòng)和清理。假設(shè)希望讓一個(gè)圖片浮動(dòng)到文本塊的左邊,并且希望這幅圖片和文本包含在另一個(gè)具有背景顏色和邊框的元素中。您可能編寫(xiě)下面的代碼:
.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è)問(wèn)題。因?yàn)楦?dòng)元素脫離了文檔流,所以包圍圖片和文本的 div 不占據(jù)空間。
如何讓包圍元素在視覺(jué)上包圍浮動(dòng)元素呢?需要在這個(gè)元素中的某個(gè)地方應(yīng)用 clear:

不幸的是出現(xiàn)了一個(gè)新的問(wèn)題,由于沒(méi)有現(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)行布局而添加無(wú)意義的標(biāo)記。
不過(guò)我們還有另一種辦法,那就是對(duì)容器 div 進(jìn)行浮動(dòng):
.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>
這樣會(huì)得到我們希望的效果。不幸的是,下一個(gè)元素會(huì)受到這個(gè)浮動(dòng)元素的影響。為了解決這個(gè)問(wèn)題,有些人選擇對(duì)布局中的所有東西進(jìn)行浮動(dòng),然后使用適當(dāng)?shù)挠幸饬x的元素(常常是站點(diǎn)的頁(yè)腳)對(duì)這些浮動(dòng)進(jìn)行清理。這有助于減少或消除不必要的標(biāo)記。
事實(shí)上,W3School 站點(diǎn)上的所有頁(yè)面都采用了這種技術(shù),如果您打開(kāi)我們使用 CSS 文件,您會(huì)看到我們對(duì)頁(yè)腳的 div 進(jìn)行了清理,而頁(yè)腳上面的三個(gè) div 都向左浮動(dòng)。
相關(guān)文章
- 這篇文章主要為大家詳細(xì)介紹了CSS3定位和浮動(dòng)的概念,以及實(shí)例代碼講解CSS3定位和浮動(dòng)的使用方法,感興趣的小伙伴們可以參考一下2016-05-10
css的核心內(nèi)容 標(biāo)準(zhǔn)流、盒子模型、浮動(dòng)、定位等分析
css的核心內(nèi)容:標(biāo)準(zhǔn)流、盒子模型、浮動(dòng)、定位(可以說(shuō)不理解這些概念絕做不出合適的網(wǎng)頁(yè))2009-12-21純CSS定位的固定垂直居中浮動(dòng)層代碼,附經(jīng)典解說(shuō) 《詳解定位與定位應(yīng)用
關(guān)于在html中浮動(dòng)層是眾多網(wǎng)頁(yè)愛(ài)好者剛開(kāi)始的難點(diǎn),主要在于定位。如果你對(duì)CSS定位還不夠了解 可以接著往下看,運(yùn)行里面的內(nèi)容即可。 【需求】: 將一個(gè)網(wǎng)頁(yè)分成頭、身2009-07-01CSS實(shí)現(xiàn)網(wǎng)頁(yè)分欄布局的方法:絕對(duì)定位和浮動(dòng)
網(wǎng)頁(yè)制作Webjx文章簡(jiǎn)介:在CSS中,實(shí)現(xiàn)分欄布局有兩種方法。第一種方法是使用四種CSS定位選項(xiàng)(absolute 、static、relative和fixed)中的絕對(duì)定位(absolute positioning2009-04-02css 浮動(dòng)(float)頁(yè)面布局(下)
我們接著上節(jié)課,繼續(xù)學(xué)習(xí),我把頁(yè)面整體效果發(fā)出來(lái),方便大家學(xué)習(xí)2010-01-07- 前四節(jié)的大練習(xí)大家做的怎么樣?有沒(méi)有難度,如果你覺(jué)著有難度沒(méi)有關(guān)系,這節(jié)課,我?guī)е蠹易鲆幌逻@個(gè)練習(xí)!2010-01-07
- DIV+CSS網(wǎng)頁(yè)布局常用到浮動(dòng)方案,但浮動(dòng)并不像表格那樣好用,很多時(shí)候會(huì)出問(wèn)題。同時(shí)設(shè)計(jì)不夠良好的浮動(dòng)布局,在不同的瀏覽器下會(huì)有不同的表現(xiàn),可能設(shè)計(jì)時(shí)照著常用的瀏覽2009-10-28
- 在CSS中,實(shí)現(xiàn)分欄布局有兩種方法。第一種方法是使用四種CSS定位選項(xiàng)(absolute 、static、relative和fixed)中的絕對(duì)定位(absolute positioning),它可以將文檔中的某個(gè)元素2009-07-01
網(wǎng)頁(yè)布局 CSS簡(jiǎn)單實(shí)現(xiàn)垂直居中-CSS教程-網(wǎng)頁(yè)制作-網(wǎng)頁(yè)教學(xué)網(wǎng)
英文原文: http://www.search-this.com/2008/05/15/easy-vertical-centering-with-css/ 中文譯文: http://www.12sui.cn/blog/71.html 本人英語(yǔ)還沒(méi)過(guò)四級(jí),所以不2008-10-17