任務10-浮動、定位

課程目標

  • 掌握定位的幾種方式
  • 掌握浮動的原理及應用
  • 理解文檔流的概念
  • 使用定位、浮動實現常見布局

學習建議

定位、浮動是 CSS 核心知識點

課程任務

1. 文檔流的概念是什么?有哪些方式可以讓元素脫離文檔流?

文檔流(normal flow),指語言文本從左到右,從上到下顯示,這是傳統 HTML 文檔的文本布局。

浮動(float)、絕對定位(absolute)、固定定位(fixed)這 3 種定位方式會讓元素脫離文檔流。

文檔流是相對于盒子模型講的。

文本流是相對于文子段落講的。

元素浮動之后,會讓它跳出文檔流,也就是說當它后面還有元素時,其他元素會無視它所占據了的區域,直接在它身下布局。但是文字卻會認同浮動元素所占據的區域,圍繞它布局,也就是沒有拖出文本。

但是絕對定位后,不僅元素盒子會拖出文檔流,文字也會出文本流。那么后面元素的文本就不會在認同它的區域位置,會直接在它后面布局,不會在環繞。
當然你可以使用 index-z 來讓底部的元素到上面來,類似于一個圖層的概念。

拓展閱讀:
  1. HTML 的文檔流和文本流分別是什么?
  2. css絕對定位、相對定位和文檔流的那些事

2. 有幾種定位方式,分別是如何實現定位的,使用場景如何?

定位

CSS 定位 (Positioning) 屬性允許你對元素進行定位。定位的基本思想很簡單,它允許你定義元素框相對于其正常位置應該出現的位置,或者相對于父元素,另一個元素甚至瀏覽器窗口本身的位置。

CSS 有 3 種基本的定位機制:普通流(文檔流)、浮動和絕對定位。

static,默認值。沒有定位,元素出現在正常的流中。(忽略 top, bottom, left, right 或者 z-index 聲明)。

relative 生成相對定位的元素,相對于其本來正常位置進行定位。且沒有脫離文檔流

fixed 是相對于瀏覽器窗口定位,即使窗口滾動,它也不會移動。且脫離文檔流(因此,不占據空間。)

absolute 絕對定位的元素的位置相對于 最近的已定位父元素 (即已用 relative、absolute 或者 fixed 定位過的),如果元素沒有已定位的父元素,那么它的位置相對于<html>。且讓元素脫離文檔流。

tips:
  1. 默認 z-index 是 0,所以如果設置 z-index 為負值,就會在“整個”的下面。
  2. 浮動和絕對定位可以讓元素脫離文檔流。
  3. 所以元素如果沒有設置 position: relative, absolute, 或者 fixed。那么設置的 top, bottom, left, right, z-index 都是沒有用的。
  4. 相對定位元素 (relative) ,經常被用來作為絕對定位元素(absolute)的容器塊。

3. absulute,relativefixed 偏移的參考點分別是什么?

absolute 的參考點是最近已定位的父元素或者根節點。

relative 的參考點是其本來的原位置

fixed 的參考點是瀏覽器窗口。

4. z-index 有什么作用?如何使用?

z-index 指定一個元素的堆疊順序。數值大的元素處于數值小的元素上面(可以為負數)。數值越大,離你越近。

注意: z-index 進行定位元素(position:absolute, position:relative, or position:fixed)。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>z-index</title>
    <style media="screen">
        img {
            position: absolute;
            z-index: -1;
        }
    </style>
</head>
<body>
    <img src="goutou.jpg" alt="dog" />
    <h1>測試 z-index測試 z-index測試 z-index測試 z-index</h1>
    <h1>測試 z-index測試 z-index測試 z-index測試 z-index</h1>
    <h1>測試 z-index測試 z-index測試 z-index測試 z-index</h1>
    <h1>測試 z-index測試 z-index測試 z-index測試 z-index</h1>
    <h1>測試 z-index測試 z-index測試 z-index測試 z-index</h1>
    <h1>測試 z-index測試 z-index測試 z-index測試 z-index</h1>
</body>
</html>
z-index1.png

position: absolute;使圖片脫離普通流。且z-index: -1;令圖片在文字下面(默認 z-index 為 0)。

若改為:

img {
     position: absolute;
     z-index: 1;
 }
()

則圖片 z-index 大于文字默認的 z-index,令圖片在文字上面。

5. position:relative 和負 margin 都可以使元素位置發生偏移?二者有什么區別?

position: relative;
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Relative 與 負margin</title>
    <style media="screen">
        .container {
            width: 200px;
            height: 200px;
            border: 1px solid;
        }
        .box1 {
            width: 50px;
            height: 50px;
            background-color: red;
            position: relative;
            top: 10px;
            left: 30px;
        }
        .box2 {
            width: 50px;
            height: 50px;
            background-color: blue;
        }
        .box3 {
            width: 50px;
            height: 50px;
            background-color: green;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="box1"></div>
        <div class="box2"></div>
        <div class="box3"></div>
    </div>
</body>
</html>
relative.png

紅色 box1 脫離本來的位置,但是原本占據的空間并沒有被其他 box 占據。

負 margin

.box2 {
            width: 50px;
            height: 50px;
            background-color: blue;
            /*margin-left: -20px;*/
            /*margin-right: -200px;*/
            /*margin-bottom: -30px;*/
            margin-top: -30px;
        }
負margin.png

藍色box2直接頂上去了,而且接著的綠色box3也跟著一起往上移。

拓展閱讀:
  1. 負margin用法權威指南
  2. 負margin的總結

6. 如何讓一個固定寬高的元素在頁面上垂直水平居中?

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>如何讓一個固定寬高的元素在頁面上垂直水平居中</title>
    <style media="screen">
        .box {
            width: 100px;
            height: 100px;
            background-color: red;
            position: absolute;
            left: 50%;
            top: 50%;
            margin-left: -50px;
            margin-top: -50px;
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>
div垂直水平居中.png

思路:絕對定位,left: 50%; + top: 50%;(這是,只是左上角的點居中了)再加上 margin-left: -50px; + margin-top: -50px; (移動半邊長的距離,令 div 的“中心”移動到外面父元素的“中心”)。

7. 浮動元素有什么特征?對其他浮動元素、普通元素、文字分別有什么影響?

浮動,浮動的框可以向左或者向右移動,直到它的外邊緣碰到包含框或者另一個浮動框的邊框為止。由于浮動框不在文檔的普通流中,所以,文檔的普通流中的塊框表現得就像浮動框不存在一樣。

特征:
  1. 內聯元素支持寬高
  2. 無論是塊元素還是內聯元素,沒有寬度時默認內容撐開寬度
  3. 脫離文檔流
對其他浮動元素的影響:

后浮動的元素永遠不會超過先浮動的元素

對普通元素的影響:

浮動元素會脫離普通流,使得周圍的元素發生偏移

對文字的影響:

浮動元素不會影響到文字的顯示,文字會相對于浮動元素發生偏移

tips:
  1. 文字可以圍繞在浮動框周圍(類似于 office 的“圍繞圖片的文字”)
  2. 浮動只有向左或者向右,而沒有自動向上一說。
  3. 塊元素浮動,占據的空間就變為“行內元素”,不占據一整行。浮動元素占據的空間(如果沒有設置 width ),會按本身內容而定,就像“行內元素”一樣。absolute 也會有類似的效果

8. 清除浮動指什么?如何清除浮動?

元素在浮動之前,是在標準流的,是豎向排列的。而浮動之后,可以理解為橫向排列。

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

demo1
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style media="screen">
        .box1 {
            width: 200px;
            height: 100px;
            background-color: red;
            float: left;
            clear: right;
        }
        .box2 {
            width: 500px;
            height: 300px;
            background-color: blue;
            float: left;
        }
    </style>
</head>
<body>
    <div class="box1"></div>
    <div class="box2"></div>
</body>
</html>
清除浮動1.png

.box1 用了clear: right;,但是 .box2 仍然在 .box1 的右邊。可見,并沒有清除浮動。


demo2
.box1 {
            width: 200px;
            height: 100px;
            background-color: red;
            float: left;
            /*clear: right;*/
        }
        .box2 {
            width: 500px;
            height: 300px;
            background-color: blue;
            float: left;
            clear: left;
        }
清除浮動2.png

.box2 用了 clear: left;,由圖可知,已清除浮動。


綜合2個 demo,得知,對于 清除浮動(clear),這個規則只能影響使用清除的元素本身,不能影響其他元素。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,345評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,494評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 176,283評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,953評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,714評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,186評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,255評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,410評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,940評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,776評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,976評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,518評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,210評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,642評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,878評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,654評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,958評論 2 373

推薦閱讀更多精彩內容

  • 一、文檔流的概念指什么?有哪種方式可以讓元素脫離文檔流? 1、文檔流指的是元素在排列布局中所占用的位置,具體的說是...
    鴻鵠飛天閱讀 795評論 0 0
  • 學習建議 定位、浮動是 CSS 核心知識點,必須熟練掌握。 1.文檔流的概念指什么?有哪種方式可以讓元素脫離文檔流...
    饑人谷_任磊閱讀 1,103評論 0 3
  • 問答 1.浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 浮動元素的特征:文字環繞浮動...
    liushaung閱讀 396評論 0 3
  • 1. 文檔流的概念指什么?有哪種方式可以讓元素脫離文檔流? 文檔流(normal flow)元素由上到下、由左到右...
    mint9602閱讀 286評論 0 0
  • 孩子 今天是媽媽第一次離開你 今晚身邊 沒有媽媽的陪伴 你可還會睡的香甜 媽媽的心 顫抖著 矛盾著 盼望著你把媽媽...
    17清雨閱讀 181評論 0 0