男女做爽爽爽网站-男女做羞羞高清-男女做爰高清无遮挡免费视频-男女做爰猛烈-男女做爰猛烈吃奶啪啪喷水网站-内射白浆一区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

CSS 終于在 2024 年增加了垂直居中功能

freeflydom
2025年3月14日 15:15 本文熱度 779

本文翻譯自 CSS finally adds vertical centering in 2024?,作者:James Smith, 略有刪改。

在 2024 年的 CSS 原生屬性中允許使用 1 個 CSS 屬性 align-content: center進行垂直居中。

<div style="align-content: center; height: 100px;">
  <code>align-content</code> 就是這么簡單!
</div>

支持情況:

Chrome: 123Firefox: 125Safari: 17.4

CSS 對齊一般會使用 flexbox 或 grid 布局,因為 align-content 在默認的流式布局中不起作用。在 2024 年,瀏覽器實現了 align-content

  • 你不需要 flexbox 或 grid,只需要 1 個 CSS 屬性就可以進行對齊。
  • 因此內容不需要包裹在 div 中。
<!-- 有效 -->
<div style="display: grid; align-content: center;">
  內容。
</div>
<!-- 失敗!-->
<div style="display: grid; align-content: center;">
  包含 <em>多個</em> 節點的內容。
</div>
<!-- 包裝div有效 -->
<div style="display: grid; align-content: center;">
  <div>  <!-- 額外的包裝器 -->
    包含 <em>多個</em> 節點的內容。
  </div>
</div>
<!-- 無需包裝div即可工作 -->
<div style="align-content: center;">
  包含 <em>多個</em> 節點的內容。
</div>

令人驚訝的是,經過幾十年的發展,CSS 終于有了 一個屬性 來控制垂直對齊!

垂直居中的歷史

瀏覽器很有趣,像對齊這樣的基本需求長期以來都沒有簡單的答案。以下是在瀏覽器中垂直居中的方法(水平居中是另一個話題):

方法 1: 表格單元格

星級:★★★☆☆

有 4 種主要布局:流(默認)、表格、flexbox、grid。如何對齊取決于容器的布局。Flexbox 和 grid 相對較晚添加,所以表格是第一種方式。

<div style="display: table;">
  <div style="display: table-cell; vertical-align: middle;">
    內容。
  </div>
</div>

方法 2: 絕對定位

星級:☆☆☆☆☆

通過絕對定位間接的方式來實現這個效果。

<div style="position: relative;">
  <div style="position: absolute; top: 50%; transform: translateY(-50%);">
    內容。
  </div>
</div>

這個方式通過絕對定位來繞過流式布局:

  • 用 position: relative 標記參考容器。
  • 用 position: absolute; top: 50% 將內容的邊緣放置在中心。
  • 用 transform: translateY(-50%) 將內容中心偏移到邊緣。

方法 3: 內聯內容

星級:☆☆☆☆☆

雖然流布局對內容對齊沒有幫助。它允許在一行內進行垂直對齊。那么為什么不使一行和容器一樣高呢?

<div class="container">
  ::before
  <div class="content">內容。</div>
</div>
.container::before {
  content: '';
  height: 100%;
  display: inline-block;
  vertical-align: middle;
}
.content {
  display: inline-block;
  vertical-align: middle;
}

這個方式有一個缺陷,需要額外創建一個偽元素。

方法 4: 單行 flexbox

星級:★★★☆☆

現在布局中的 Flexbox 變得廣泛可用。它有兩種模式:單行和多行。在單行模式(默認)中,行填充垂直空間,align-items 對齊行內的內容。

<div style="display: flex; align-items: center;">
  <div>內容。</div>
</div>

或者調整行為列,并用 justify-content 對齊內容。

<div style="display: flex; flex-flow: column; justify-content: center;">
  <div>內容。</div>
</div>

方法 5: 多行 flexbox

星級:★★★☆☆

在多行 flexbox 中,行不再填充垂直空間,所以行(只有一個項目)可以用 align-content 對齊。

<div style="display: flex; flex-flow: row wrap; align-content: center;">
  <div>內容。</div>
</div>

方法 6: grid

星級:★★★★☆

Grid 出來的更晚,對齊變得更簡單。

<div style="display: grid; align-content: center;">
  <div>內容。</div>
</div>

方法 7: grid 單元格

星級:★★★★☆

注意與前一個方法的微妙區別:

  • align-content 將單元格居中到容器。
  • align-items 將內容居中到單元格,同時單元格拉伸以適應容器。
<div style="display: grid; align-items: center;">
  <div>內容。</div>
</div>

似乎有很多方法可以做同一件事。

方法 8: margin:auto

星級:★★★☆☆

在流布局中,margin:auto 可以水平居中,但不是垂直居中。使用 margin-block: auto 可以設置垂直居中。

<div style="display: grid;">
  <div style="margin-block: auto;">
    內容。
  </div>
</div>

方法 9: 這篇文章的開頭

星級:★★★★★

為什么瀏覽器最初沒有添加這個?

<div style="align-content: center;">
  <code>align-content</code> 就是這么簡單!
</div>

總結

CSS 的新特性 align-content 提供了一個簡單且直接的方式來實現垂直居中,無需使用額外的div包裝或復雜的布局模式即可完成垂直居中。但注意這個屬性還存在一定的瀏覽器兼容性,在線上使用需謹慎。

轉自https://juejin.cn/post/7408097468796551220


該文章在 2025/3/14 15:19:16 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 日本高清无卡码一区二区久久 | 日韩一区二区三区中文 | 久久一本热 | av大片免费看中文字幕 | 日韩成人网站 | 亚洲精品一区二区三区四区手机版 | 久久精品国产99久久久香蕉 | 精品国产乱码久久久久久1区2区 | 水蜜桃亚洲一二三四在线 | 人妻av无码一区二区三区 | 久久精品伊人无码一区 | 国产成人免费 | 久久久久久国产精品三级 | 欧美女视频网站大全在线观看 | 国产欧美日韩久久久久 | 国产精品久久久久久久免费大片 | 国产精品成av人在线观看片 | 国产三级电影经典在线看 | 亚洲免费人成 久久 | 国产免费久久精品99re丫y | a级一级黄色片 | 99热这里只有精品中文 | 麻豆吧| 中国少妇内射xxxhd | 日韩激情视频一区二区三区 | 天堂在线中文字幕 | 女女同性女同一区二区三区 | 国产精品美女久久久久av爽 | 麻豆aⅴ精品无码一区二区 麻豆app2.24.15.15安卓版下载 | 中文字幕欧美aⅴ字幕 | 中文国产成人精品久久不卡 | 日本熟妇乱妇熟色A片在线观看 | 久久青青无码AV亚洲黑人 | 丁香五月亚洲综合在线国内自拍 | 美日韩在线视频 | 成人久久精品国产亚洲v大全 | AV永久无码麻豆A片 av永久永久永久在线 | 国产精品理论片在线观看 | 亚洲精品乱码久久久久久 | 久久视频在线视频观看2019 | 人妻无码中文专区久久AV |