跳到主要內容 跳到文檔導航
in English

斷點

斷點是可自定義的寬度,它決定了響應式佈局在 Bootstrap 中跨設備或視口大小的行為方式。

核心概念

  • 斷點是響應式設計的基石。使用它們來控制您的佈局何時可以適應特定的視口或設備尺寸。

  • 使用媒體查詢通過斷點來構建你的 CSS。媒體查詢是 CSS 的一項功能,它允許您根據一組瀏覽器和操作系統參數有條件地應用樣式。我們最常用於min-width媒體查詢。

  • 移動優先,響應式設計是目標。Bootstrap 的 CSS 旨在應用最少的樣式以使佈局在最小的斷點處工作,然後對樣式進行分層以針對更大的設備調整該設計。這可以優化您的 CSS,縮短渲染時間,並為您的訪問者提供出色的體驗。

可用斷點

Bootstrap 包括六個默認斷點,有時稱為網格層,用於響應式構建。如果您使用我們的源 Sass 文件,可以自定義這些斷點。

斷點 類中綴 方面
X-小 沒有任何 <576 像素
小的 sm ≥576像素
中等的 md ≥768像素
大的 lg ≥992像素
特大號 xl ≥1200像素
特大號 xxl ≥1400像素

選擇每個斷點以舒適地容納寬度為 12 的倍數的容器。斷點還代表了常見設備大小和視口尺寸的子集——它們並不專門針對每個用例或設備。相反,這些範圍為幾乎任何設備提供了強大而一致的基礎。

_variables.scss這些斷點可通過 Sass 進行自定義——您可以在我們樣式表的 Sass 映射中找到它們。

$grid-breakpoints: (
  xs: 0,
  sm: 576px,
  md: 768px,
  lg: 992px,
  xl: 1200px,
  xxl: 1400px
);

有關如何修改 Sass 映射和變量的更多信息和示例,請參閱Grid 文檔的 Sass 部分

媒體查詢

由於 Bootstrap 是首先開發為移動設備的,因此我們使用一些媒體查詢來為我們的佈局和界面創建合理的斷點。這些斷點主要基於最小視口寬度,並允許我們隨著視口的變化放大元素。

最小寬度

Bootstrap 主要在我們的 Sass 源文件中為我們的佈局、網格系統和組件使用以下媒體查詢範圍或斷點。

// Source mixins

// No media query necessary for xs breakpoint as it's effectively `@media (min-width: 0) { ... }`
@include media-breakpoint-up(sm) { ... }
@include media-breakpoint-up(md) { ... }
@include media-breakpoint-up(lg) { ... }
@include media-breakpoint-up(xl) { ... }
@include media-breakpoint-up(xxl) { ... }

// Usage

// Example: Hide starting at `min-width: 0`, and then show at the `sm` breakpoint
.custom-class {
  display: none;
}
@include media-breakpoint-up(sm) {
  .custom-class {
    display: block;
  }
}

這些 Sass mixin 使用 Sass 變量中聲明的值在我們編譯的 CSS 中進行轉換。例如:

// X-Small devices (portrait phones, less than 576px)
// No media query for `xs` since this is the default in Bootstrap

// Small devices (landscape phones, 576px and up)
@media (min-width: 576px) { ... }

// Medium devices (tablets, 768px and up)
@media (min-width: 768px) { ... }

// Large devices (desktops, 992px and up)
@media (min-width: 992px) { ... }

// X-Large devices (large desktops, 1200px and up)
@media (min-width: 1200px) { ... }

// XX-Large devices (larger desktops, 1400px and up)
@media (min-width: 1400px) { ... }

最大寬度

我們偶爾會使用相反方向的媒體查詢(給定的屏幕尺寸或更小):

// No media query necessary for xs breakpoint as it's effectively `@media (max-width: 0) { ... }`
@include media-breakpoint-down(sm) { ... }
@include media-breakpoint-down(md) { ... }
@include media-breakpoint-down(lg) { ... }
@include media-breakpoint-down(xl) { ... }
@include media-breakpoint-down(xxl) { ... }

// Example: Style from medium breakpoint and down
@include media-breakpoint-down(md) {
  .custom-class {
    display: block;
  }
}

這些 mixin 獲取那些聲明的斷點,.02px從中減去,並將它們用作我們的max-width值。例如:

// X-Small devices (portrait phones, less than 576px)
@media (max-width: 575.98px) { ... }

// Small devices (landscape phones, less than 768px)
@media (max-width: 767.98px) { ... }

// Medium devices (tablets, less than 992px)
@media (max-width: 991.98px) { ... }

// Large devices (desktops, less than 1200px)
@media (max-width: 1199.98px) { ... }

// X-Large devices (large desktops, less than 1400px)
@media (max-width: 1399.98px) { ... }

// XX-Large devices (larger desktops)
// No media query since the xxl breakpoint has no upper bound on its width
為什麼要減去 .02px?瀏覽器目前不支持 範圍上下文查詢,因此我們通過使用精度更高的值來解決具有小數寬度的 前綴min-max-視口的限制(例如,在高 dpi 設備上的某些條件下可能發生)。

單斷點

還有媒體查詢和混合使用最小和最大斷點寬度來定位單個屏幕尺寸段。

@include media-breakpoint-only(xs) { ... }
@include media-breakpoint-only(sm) { ... }
@include media-breakpoint-only(md) { ... }
@include media-breakpoint-only(lg) { ... }
@include media-breakpoint-only(xl) { ... }
@include media-breakpoint-only(xxl) { ... }

例如,@include media-breakpoint-only(md) { ... }將導致:

@media (min-width: 768px) and (max-width: 991.98px) { ... }

斷點之間

同樣,媒體查詢可能跨越多個斷點寬度:

@include media-breakpoint-between(md, xl) { ... }

結果是:

// Example
// Apply styles starting from medium devices and up to extra large devices
@media (min-width: 768px) and (max-width: 1199.98px) { ... }