CSS中Padding與Margin的區別

一、Margin與Padding的定義

Margin指的是元素邊框與相鄰元素之間的距離,而Padding指的是元素邊框到元素內容之間的距離。

二、Margin與Padding的用途

Margin常用於控制元素與其他元素的距離,例如布局中的邊距或間距。Padding常用於控制元素內容與元素邊框之間的距離,可以用於控制元素內容的顯示。

三、Margin與Padding的取值方式

Margin和Padding都可以取正數、負數、百分比、em、rem等單位。

四、Margin與Padding的優先順序

當一個元素同時存在Margin和Padding屬性時,CSS會按照以下順序優先使用:

1. 相鄰元素之間的margin不能重疊;

/* margin-top為相鄰元素間距離,而不是與上方元素的間距 */
div{
    margin: 20px 0;
} 

2. 對於相鄰的兩個方向的margin取最大值;

/* 相鄰左右兩邊的margin取右邊的值為準 */
div{
    margin: 0 20px 0 30px;
} 

3. 相同方向的margin取最大值;

/* margin-top為30,margin-bottom為50,取50為最大值 */
div{
    margin: 30px 0 50px 0;
} 

4. 若一個方向有正數和負數的margin值,則縱向兩者相加,橫向兩者取最大值。

/* margin-top: 20px, margin-bottom: -30px, 上下相消,margin: 10px */
div{
    margin: 20px 0 -30px 0;
} 

五、Margin與Padding的注意點

1. Margin和Padding都會影響元素的計算寬高;

2. 在box-sizing屬性為content-box時,元素計算寬高不包括padding和border,但包括margin;在box-sizing屬性為border-box時,元素計算寬高包括padding、border和content,但不包括margin。

/* include padding and border, exclude margin */
div{
    box-sizing: border-box;
}

3. 相鄰元素的margin屬性會合併,產生重疊現象,稱為margin collapse。當相鄰兩個元素的margin都是正數時,合併後的距離為兩者間距離的最大值,當一正一負或兩個都是負數時,合併後的距離為兩者間距離的疊加值。

/* 兩個塊級元素間距離是40px */
div{
    margin: 20px;
} 

4. 當設置了元素的overflow屬性為auto、scroll或hidden時,padding會影響元素滾動條的位置。

/* 水平滾動條移到padding以外的區域 */
div{
    overflow-x: auto;
    padding: 20px;
}

六、Margin與Padding的實例

以一個簡單的布局為例:

頭部

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

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

相關推薦

  • 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

發表回復

登錄後才能評論