CSS box-sizing:border-box應用詳解

一、什麼是box-sizing

box-sizing是CSS3新增的一個屬性,用於控制元素寬高的計算方式,常見的有兩種值:

box-sizing: content-box;  // 默認值,寬高只計算內容區域
box-sizing: border-box;   // 寬高計算包括內容、內邊距和邊框

box-sizing屬性的主要作用是讓開發者控制元素的盒模型,從而更加靈活地進行頁面布局。下面我們來看一些實際應用。

二、box-sizing實戰-響應式布局

在移動端開發中,響應式布局是比較常見的技術,使用box-sizing可以很好地實現這一點。我們可以通過設置所有元素的box-sizing為border-box,然後使用百分比作為寬度,達到自適應的效果。

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.box {
  width: 25%;
  padding: 20px;
  float: left;
}

在上面的代碼中,我們將所有元素都設置為border-box盒模型,這樣可以計算內邊距和邊框的寬高,避免了使用傳統的盒模型(content-box)時會出現的盒子寬度換算問題。接著,設置.container寬度為100%,防止盒子超出父容器,然後限制最大寬度為1200px,實現響應式布局。最後是.box的樣式,寬度為25%時,可以自適應寬度,而padding的值不會改變寬度,均布四個盒子。

三、box-sizing實戰-響應式表格

使用box-sizing實現響應式表格也是一種常見的技術。我們可以使用border-spacing屬性來控制單元格間距,同時設置單元格寬度為百分比,使用box-sizing: border-box屬性。這樣可以實現表格在不同尺寸的設備上自適應的效果。

table {
  border-collapse: separate;
  border-spacing: 0px;
  width: 100%;
}

td {
  width: 50%;
  padding: 10px;
  box-sizing: border-box;
}

在上面的代碼中,通過設置table的border-collapse為separate,使單元格有一個邊框。同時,使用border-spacing: 0px來控制單元格的間距。接著,設置td的寬度為50%和 padding 10px,實現表格單元格水平分布和自適應。

四、box-sizing實戰-圖片自適應

當圖片大小不同時,如何保持圖片的比例不受影響呢?可以使用box-sizing實現圖片自適應的效果。我們可以將圖片包裹在div中,將box-sizing設為border-box、將div的padding-bottom屬性值設置為圖片高度與寬度比例的百分比。

.wrapper {
  position: relative;
  width: 100%;
}

.img-box {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  max-width: 100%;
  max-height: 100%;
  box-sizing: border-box;
  padding-bottom: 75%; // 圖片高度與寬度比例為4:3
}

.img-box img {
  display: block;
  max-width: 100%;
  max-height: 100%;
}

在上面的代碼中,我們用div包含了圖片,將其放在一個相對定位的wrapper中,然後用絕對定位的方式將div居中。接著,將div的width設置成100%,padding-bottom設置成圖片高度與寬度的比例(這裡是4:3)。最後再將img的max-width和max-height都設置為100%,實現圖片的自適應效果。

總結

box-sizing屬性使得開發者可以更加靈活地控制元素的盒模型,較好地實現手機端的響應式布局、響應式表格、圖片自適應等效果。使用box-sizing: border-box時,需要注意內邊距和邊框的寬高計算問題,從而準確計算元素的實際大小。

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

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

相關推薦

  • CSS sans字體家族

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

    編程 2025-04-28
  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁碟中。在執行sync之前,所有的文件系統更新將不會立即寫入磁碟,而是先緩存在內存…

    編程 2025-04-25
  • 神經網路代碼詳解

    神經網路作為一種人工智慧技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網路的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網路模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • Java BigDecimal 精度詳解

    一、基礎概念 Java BigDecimal 是一個用於高精度計算的類。普通的 double 或 float 類型只能精確表示有限的數字,而對於需要高精度計算的場景,BigDeci…

    編程 2025-04-25
  • C語言貪吃蛇詳解

    一、數據結構和演算法 C語言貪吃蛇主要運用了以下數據結構和演算法: 1. 鏈表 typedef struct body { int x; int y; struct body *nex…

    編程 2025-04-25
  • Linux修改文件名命令詳解

    在Linux系統中,修改文件名是一個很常見的操作。Linux提供了多種方式來修改文件名,這篇文章將介紹Linux修改文件名的詳細操作。 一、mv命令 mv命令是Linux下的常用命…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分散式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25
  • Python安裝OS庫詳解

    一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變數讀取等系統級操作。 OS庫中包含了大量的文件和目…

    編程 2025-04-25
  • Python輸入輸出詳解

    一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件…

    編程 2025-04-25
  • MPU6050工作原理詳解

    一、什麼是MPU6050 MPU6050是一種六軸慣性感測器,能夠同時測量加速度和角速度。它由三個感測器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其…

    編程 2025-04-25

發表回復

登錄後才能評論