CSS定位:相對定位和絕對定位的區別

一、CSS絕對定位與相對定位的區別

1、絕對定位和相對定位都可以控制元素在頁面上的位置,但二者的定位方式和影響範圍有所不同。

2、相對定位是相對於元素本身所在位置來進行定位,可以通過top、bottom、left、right屬性的設定來控制元素所在位置的偏移量,影響僅限於該元素所在的文本流中。

.box {
  position: relative; /*相對定位*/
  top: 20px;
  left: 50px;
}

3、絕對定位是相對於距離自身最近的已定位的祖先元素,如果不存在已定位的祖先元素,則相對於文檔的body元素來進行定位。可以通過top、bottom、left、right屬性的設定來控制元素所在位置的偏移量,影響範圍比相對定位更廣泛。

.box {
  position: absolute; /*絕對定位*/
  top: 20px;
  left: 50px;
}

二、相對定位、絕對定位和固定定位的區別

1、固定定位是指元素相對於瀏覽器視窗的位置進行定位,不會隨着滾動條的滾動而變化。

.box {
  position: fixed; /*固定定位*/
  top: 20px;
  left: 50px;
}

2、相對定位、絕對定位和固定定位在使用時需要注意以下幾點差異:

3、相對定位是相對於元素本身所在位置來進行定位,而絕對定位和固定定位是相對於祖先元素和瀏覽器視窗來進行定位,所以在使用時需要對祖先元素和瀏覽器視窗的大小進行適當的考慮。

.relative-box {
  position: relative;
  width: 400px;
  height: 300px;
}

.absolute-box {
  position: absolute;
  width: 200px;
  height: 200px;
  top: 50px;
  left: 50px;
}

.fixed-box {
  position: fixed;
  width: 200px;
  height: 200px;
  bottom: 50px;
  right: 50px;
}

4、另外,相對定位、絕對定位和固定定位在文檔流中的位置也有所不同,相對定位不會改變元素在文檔流中的位置,但是絕對定位和固定定位會將元素從文檔流中拖出來,可能會對其他元素造成影響,需要進行一定的頁面布局規劃。

三、使用示例

.relative-box {
  position: relative;
  width: 400px;
  height: 300px;
}

.absolute-box {
  position: absolute;
  width: 200px;
  height: 200px;
  top: 50px;
  left: 50px;
}

.fixed-box {
  position: fixed;
  width: 200px;
  height: 200px;
  bottom: 50px;
  right: 50px;
}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/193535.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-01 15:02
下一篇 2024-12-01 15:02

相關推薦

  • Python中new和init的區別

    new和init都是Python中常用的魔法方法,它們分別負責對象的創建和初始化,本文將從多個角度詳細闡述它們的區別。 一、創建對象 new方法是用來創建一個對象的,它是一個類級別…

    編程 2025-04-29
  • Sublime Test與Python的區別

    Sublime Text是一款流行的文本編輯器,而Python是一種廣泛使用的編程語言。雖然Sublime Text可以用於編寫Python代碼,但它們之間有很多不同之處。接下來從…

    編程 2025-04-29
  • Shell腳本與Python腳本的區別

    本文將從多個方面對Shell腳本與Python腳本的區別做詳細的闡述。 一、語法差異 Shell腳本和Python腳本的語法存在明顯差異。 Shell腳本是一種基於字符命令行的語言…

    編程 2025-04-29
  • Python中while語句和for語句的區別

    while語句和for語句是Python中兩種常見的循環語句,它們都可以用於重複執行一段代碼。然而,它們的語法和適用場景有所不同。本文將從多個方面詳細闡述Python中while語…

    編程 2025-04-29
  • Web程序和桌面程序的區別

    Web程序和桌面程序都是進行軟件開發的方式,但是它們之間存在很大的區別。本文將從多角度進行闡述。 一、運行方式 Web程序運行於互聯網上,用戶可以通過使用瀏覽器來訪問它。而桌面程序…

    編程 2025-04-29
  • TensorFlow和Python的區別

    TensorFlow和Python是現如今最受歡迎的機器學習平台和編程語言。雖然兩者都處於機器學習領域的主流陣營,但它們有很多區別。本文將從多個方面對TensorFlow和Pyth…

    編程 2025-04-28
  • 麥語言與Python的區別

    麥語言和Python都是非常受歡迎的編程語言。它們各自有自己的優缺點和適合的應用場景。本文將從語言特性、語法、生態系統等多個方面,對麥語言和Python進行詳細比較和闡述。 一、語…

    編程 2025-04-28
  • MySQL bigint與long的區別

    本文將從數據類型定義、存儲空間、數據範圍、計算效率、應用場景五個方面詳細闡述MySQL bigint與long的區別。 一、數據類型定義 bigint在MySQL中是一種有符號的整…

    編程 2025-04-28
  • Python與C語言的區別和聯繫

    Python與C語言是兩種常用的編程語言,雖然兩者都可以用於編寫軟件程序,但是它們之間有很多不同之處。本文將從多個方面對Python與C語言的區別和聯繫進行詳細的闡述。 一、語法特…

    編程 2025-04-28
  • CSS sans字體家族

    CSS sans字體家族是一組基於CSS的無襯線字體,具有在不同設備和瀏覽器上保持一致的特性。本文將從優勢、使用、自定義等多個方面對CSS sans字體家族進行詳細介紹。 一、優勢…

    編程 2025-04-28

發表回復

登錄後才能評論