首頁 web前端 css教學 CSS之Position詳解

CSS之Position詳解

Feb 10, 2017 pm 03:48 PM
css position

CSS的許多其他屬性大多容易理解,例如字體,文本,背景等。有些CSS書籍也會對這些簡單的屬性進行大張旗鼓的介紹,而偏偏忽略了對一些難纏的屬性講解,有避重就輕的嫌疑。 CSS中主要難以理解的屬性包括盒型結構,以及定位。正如positioniseverything,本文將主要講述關於position的理解,力求讓您看完本文後對position有著最全面的認識。

position的四個屬性值:

  1. relative

  2. absolute

  3.     

    sub1

    

sub2

ative


1. rel
relative屬性相對比較簡單,我們要搞清它是相對哪個物件來進行偏移的。答案是它本身的位置。在上面的程式碼中,sub1和sub2是同級關係,如果設定sub1一個relative屬性,例如設定如下CSS程式碼:

#sub1

{
    position: relative;
    padding: 5px; left: 5px;
}


我們可以這樣理解,如果不設定relative屬性,sub1的位置按照正常的文檔流,它應該處於某個位置。但當設定sub1為的position為relative後,將根據top,right,bottom,left的值按照它理應所在的位置進行偏移,relative的「相對的」意思也正體現於此。

對於此,您只需要記住,sub1如果不設定relative時它應該在哪裡,一旦設定後就按照它理應在的位置進行偏移。

隨後的問題是,sub2的位置又在哪裡呢?答案是它原來在哪裡,現在就在哪裡,它的位置不會因為sub1增加了position的屬性而改變。

如果此時把sub2的position也設定為relative,會發生什麼現象?此時依然和sub1一樣,都依照它原來應有的位置偏移。


注意relative的偏移是基於物件的margin的左上側的。

2. absolute

這個屬性總是有人給誤導。說當position屬性設為absolute後,總是會按照瀏覽器視窗來進行定位的,這其實是錯誤的。實際上,這是fixed屬性的特徵。

當sub1的position設定為absolute後,其到底以誰為物體進行偏移呢?這裡分為兩種情況:

(1)當sub1的父對象(或曾祖父,只要是父級對象)parent也設定了position屬性,且position的屬性值為absolute或relative時,也就是說,不是預設值的情況,此時sub1就按照這個parent來進行定位。

注意,對象雖然確定好了,但有些細節需要您的注意,那就是我們到底以parent的哪個定位點來進行定位呢?如果parent設定了margin,border,padding等屬性,那麼這個定位點將忽略padding,將會從padding開始的地方(即只從padding的左上角開始)進行定位,這與我們會想當然的以為會以margin的左上端開始定位的想法是不同的。

接下來的問題是,sub2的位置到哪裡去了呢?由於當position設定為absolute後,會導致sub1溢出正常的文件流,就像它不屬於 parent一樣,它漂浮了起來,在DreamWeaver中稱它為“層”,其實意思是一樣的。此時sub2將獲得sub1的位置,而它的文件流不再基於 sub1,而是直接從parent開始。

(2)如果sub1不存在一個有著position屬性的父對象,那麼那就會以body為定位對象,按照瀏覽器的窗口進行定位,這個比較容易理解。

3. fixed

fixed是特殊的absolute,即fixed總是以body為定位物件的,按照瀏覽器的視窗進行定位。

4. static

position的預設值,一般不設定position屬性時,會依照正常的文檔流進行排列。

如果本文有任何技術或表達問題,請您留言。感謝您的閱讀!

更多CSS之Position詳解 相關文章請追蹤PHP中文網!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

VUE 3 VUE 3 Apr 02, 2025 pm 06:32 PM

它的出局!恭喜Vue團隊完成了完成,我知道這是一項巨大的努力,而且很長時間。所有新文檔也是如此。

在CI/CD上有點 在CI/CD上有點 Apr 02, 2025 pm 06:21 PM

我說的“網站”比“移動應用程序”更合適,但我喜歡Max Lynch的框架:

您可以從瀏覽器獲得有效的CSS屬性值嗎? 您可以從瀏覽器獲得有效的CSS屬性值嗎? Apr 02, 2025 pm 06:17 PM

我有人寫了這個非常合法的問題。 Lea只是在博客上介紹瞭如何從瀏覽器中獲得有效的CSS屬性。那樣的是這樣。

帶有粘性定位的堆疊卡和一點點的雜物 帶有粘性定位的堆疊卡和一點點的雜物 Apr 03, 2025 am 10:30 AM

前幾天,我發現了科里·金尼文(Corey Ginnivan)網站上的這一點,當您滾動時,彼此之間的卡片堆放集。

在WordPress塊編輯器中使用Markdown和本地化 在WordPress塊編輯器中使用Markdown和本地化 Apr 02, 2025 am 04:27 AM

如果我們需要直接在WordPress編輯器中向用戶顯示文檔,那麼最佳方法是什麼?

比較瀏覽器的響應式設計 比較瀏覽器的響應式設計 Apr 02, 2025 pm 06:25 PM

這些桌面應用程序中有許多目標是同時在不同的維度上顯示您的網站。因此,例如,您可以寫作

為什麼Flex佈局中的紫色斜線區域會被誤認為是'溢出空間”? 為什麼Flex佈局中的紫色斜線區域會被誤認為是'溢出空間”? Apr 05, 2025 pm 05:51 PM

關於Flex佈局中紫色斜線區域的疑問在使用Flex佈局時,你可能會遇到一些令人困惑的現象,比如在開發者工具(d...

如何將CSS網格用於粘頭和頁腳 如何將CSS網格用於粘頭和頁腳 Apr 02, 2025 pm 06:29 PM

CSS網格是一系列屬性的集合,旨在使佈局比以往任何時候都容易。像任何東西一樣,那裡有一點學習曲線,但是網格是

See all articles