精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

CSS 終于原生支持瀑布流布局了!

開發(fā) 前端
從 table 到 float,從 flex 到 grid,再到現(xiàn)在的 masonry,CSS 布局能力的每一次演進(jìn),都是在幫我們把“樣式”這件事做得更優(yōu)雅、更少依賴、更易維護(hù)。

你有沒有注意過,小紅書、淘寶等平臺上那種高低錯(cuò)落、緊密排列的內(nèi)容墻?

圖片圖片

這種布局叫做瀑布流布局。像圖文列表、相冊展示、電商商品頁這些地方,都特別愛用。

不過,過去如果你想用 CSS 實(shí)現(xiàn)這個(gè)效果,基本都得走些“旁門左道”:要么引入 Masonry.js 這類 JavaScript 插件,要么拿 CSS Grid 或 Flexbox 搞些變通寫法。哪種都不輕松,出了問題還挺難查。

但現(xiàn)在,好消息來了——CSS 原生支持瀑布流布局了!

只需要加上一行 display: masonry,瀏覽器就能自動幫你排好那些“不規(guī)整”的元素。不用額外的庫,也不用自己算高度,代碼更簡單,性能也更好。

接下來我們就聊聊這個(gè)新特性是怎么來的?怎么用?瀏覽器支持情況怎么樣?

過去怎么實(shí)現(xiàn)瀑布流?

用 JS 插件,比如 Masonry.js、Isotope,或者用 Grid/Flexbox 做“偽瀑布流”是過去的主流方案。

這些方式雖然能實(shí)現(xiàn)效果,但都存在一些問題:

  • 要引入額外的 JS 庫,增加加載體積;
  • 響應(yīng)式布局調(diào)整時(shí)要重新觸發(fā) JS 計(jì)算;
  • 寫法復(fù)雜,容易出錯(cuò)或有兼容性問題。

于是,很多開發(fā)者一直在呼吁:CSS 能不能直接支持瀑布流布局?

CSS Masonry 的進(jìn)化史

2017 - 2020:呼聲初起

從 2017 年起,社區(qū)里就有不少開發(fā)者在 W3C GitHub 提案、issue 區(qū)呼吁 CSS 能原生支持 Masonry。那時(shí)候 Grid 剛火不久,但也搞不定這種不規(guī)則的“磚墻式”排布。

2020 - 2024:標(biāo)準(zhǔn)化爭論

2020 年,CSS 工作組開始在 Grid Level 3 中正式探討 Masonry 語法。很快,各大瀏覽器廠商也加入討論:

  • Apple/WebKit 認(rèn)為 Masonry 是 Grid 的一種變體,主張寫法沿用 grid-template-columns: masonry
  • Google/Chromium 認(rèn)為它本質(zhì)上與 Grid 不同,主張使用 display: masonry 作為新的布局類型。

爭論持續(xù)了幾年,最終折中的結(jié)果是:兩個(gè)寫法都可以支持

2025:實(shí)驗(yàn)性支持上線

2025 年,Chrome 和 Edge 140 版本開始提供實(shí)驗(yàn)性支持:

  • 可以用 display: masonry 直接實(shí)現(xiàn)瀑布流;
  • 也可以在 Grid 中使用 grid-template-columns: masonry
  • 目前都需要手動在 chrome://flags 中開啟 Masonry Layout 選項(xiàng)。

Firefox 和 Safari 也在積極跟進(jìn)中,預(yù)計(jì) 2026 年將會穩(wěn)定支持。

原生 CSS Masonry 有哪些優(yōu)勢?

對比以往的 JavaScript 實(shí)現(xiàn),原生 CSS Masonry 有不少優(yōu)勢:

  • 更高的性能:瀏覽器引擎直接計(jì)算布局,省去了 JS 操作 DOM 的性能開銷;
  • 響應(yīng)式更輕松:窗口大小改變時(shí),瀏覽器自動處理重排,不需要再跑 JS;
  • 更少的代碼:不用引入庫,不需要監(jiān)聽 resize,不需要手寫復(fù)雜的布局邏輯;
  • 加載更快:CSS 渲染無需等 JS 執(zhí)行,頁面打開即可展示完整布局。

Chrome 團(tuán)隊(duì)測試發(fā)現(xiàn),在包含 100 個(gè)元素的瀑布流中,原生 Masonry 比 JS 方案加載速度快了大約 40%。

Masonry 的語法長什么樣?

目前有兩種寫法,對應(yīng)的是前面提到的兩種思路:一種是把 Masonry 當(dāng)作新的布局類型,另一種是把它作為 Grid 的擴(kuò)展。

寫法一:display: masonry(目前主流,推薦)

這是現(xiàn)在 Chrome 先支持的寫法,也是最簡單直接的一種。像這樣寫:

.masonry {
  display: masonry;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

你可能注意到了,這里雖然用了 display: masonry,但 grid-template-columns 依然能用。這是因?yàn)?Masonry 繼承了部分 Grid 的語法,用法也比較類似,基本不需要重新學(xué)習(xí)。

寫法二:在 Grid 中使用 masonry 值

還有一種思路,是把 Masonry 融進(jìn) Grid 的語法體系里:

.masonry {
  display: grid;
  grid-template-columns: masonry;
}

這種寫法目前還在討論中,還沒正式定下來,未來有可能成為標(biāo)準(zhǔn),但現(xiàn)在主流瀏覽器還沒支持。

怎么在瀏覽器中啟用 Masonry?

目前這個(gè)特性還屬于實(shí)驗(yàn)階段,默認(rèn)是關(guān)著的,需要手動開啟:

  1. 使用 Chrome 或 Edge 140 及以上版本;
  2. 在地址欄輸入 chrome://flags
  3. 搜索「CSS Masonry Layout」;
  4. 啟用這個(gè)功能,重啟瀏覽器就生效了。

基礎(chǔ)用法

先來個(gè)最常見的場景:橫向排列、列寬自適應(yīng)、高度不固定的卡片流。

.masonry {
  display: masonry;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
}

這段代碼會生成一個(gè)響應(yīng)式的 Masonry 容器,每列最小 200px,瀏覽器會根據(jù)容器寬度自動安排放幾列。

圖片圖片

行方向 Masonry 布局

默認(rèn) Masonry 是按列來的,但其實(shí)它也支持橫向排列(即按行 Masonry)。

只要加上 masonry-direction: row 就行:

.masonry {
  display: masonry;
  masonry-direction: row;
  grid-template-rows: repeat(auto-fit, minmax(100px, 1fr));
  gap: 16px;
}

圖片圖片

這在一些橫向滾動的內(nèi)容流、時(shí)間軸樣式中會很有用。

不指定列寬也能自動布局

一個(gè)很貼心的點(diǎn)是:你可以不寫 grid-template-columns,瀏覽器也能自己安排列數(shù)。

.masonry {
  display: masonry;
  gap: 16px;
  /* 會自動創(chuàng)建多列,不需要手動指定 */
}

這在快速搭頁面或者原型階段非常方便,不需要先想列數(shù)、也不用定寬度,效果就已經(jīng)很不錯(cuò)了。

支持跨列元素

跟 CSS Grid 一樣,Masonry 也支持讓某些元素跨越多列或整行:

.masonry {
display: masonry;
grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
gap: 16px;
}

.featured-item {
grid-column: span 2; /* 跨越兩列 */
}

.full-width {
grid-column: 1 / -1; /* 占滿整個(gè)寬度 */
}

這個(gè)特性對于制作博客、新聞頁面、突出重點(diǎn)內(nèi)容非常實(shí)用。

簡寫屬性:masonry

如果你覺得 grid-template-columns + masonry-direction 太啰嗦,也可以用官方提出的 masonry 簡寫:

.masonry {
  display: masonry;
  masonry: repeat(3, 200px) column;
}

等價(jià)于:

.masonry {
  display: masonry;
  masonry-direction: column;
  grid-template-columns: repeat(3, 200px);
}

瀏覽器支持現(xiàn)狀

瀏覽器

支持情況

說明

Chrome / Edge 140+

實(shí)驗(yàn)性支持

需要在 chrome://flags
 開啟

Firefox Nightly

實(shí)驗(yàn)性支持

需要手動啟用 layout.css.masonry.enabled

Safari / WebKit

開發(fā)中

標(biāo)準(zhǔn)參與中,尚未實(shí)現(xiàn)

雖然還不能直接上線生產(chǎn)環(huán)境,但這已經(jīng)是值得關(guān)注和試水的階段了。

寫在最后

從 table 到 float,從 flex 到 grid,再到現(xiàn)在的 masonry,CSS 布局能力的每一次演進(jìn),都是在幫我們把“樣式”這件事做得更優(yōu)雅、更少依賴、更易維護(hù)。

CSS Masonry 的到來,不僅解決了一個(gè)老大難的問題,更意味著我們能用更少的代碼、更優(yōu)的性能,實(shí)現(xiàn)更豐富的頁面表現(xiàn)。

雖然現(xiàn)在它還在實(shí)驗(yàn)階段,但相信不久的將來,瀑布流布局會像 flex 一樣,成為前端開發(fā)者的標(biāo)配工具。

我們等了它很多年,現(xiàn)在,它終于來了。

責(zé)任編輯:武曉燕 來源: 前端充電寶
相關(guān)推薦

2013-02-19 10:24:47

瀑布流布局CSS

2021-08-09 07:26:33

瀑布流布局代碼

2015-12-15 10:32:44

chromecss開發(fā)

2023-09-21 10:09:10

JavaScript數(shù)組分組

2023-08-29 09:43:21

Node.js.env

2024-08-19 14:01:00

2023-07-24 09:11:43

CSS滾動驅(qū)動動畫

2025-11-07 00:00:00

2012-05-02 13:53:00

JavaScript

2023-02-13 09:31:07

CSS前端

2025-07-04 01:55:00

CSS樣式Chrome

2023-04-10 09:18:42

CSS前端

2020-03-02 15:17:37

云原生CNCF容器

2024-09-23 09:20:02

calc-sizeCSS前端

2022-07-04 09:21:16

GNOME Web瀏覽器

2020-05-08 08:01:11

多線程Redis處理

2024-01-08 09:28:20

2023-05-29 08:38:56

popover控制懸浮層

2025-01-20 00:00:00

Java語言Record
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

欧美一区二区免费视频| 丝袜亚洲另类欧美| 精品剧情在线观看| 国产a级一级片| 黄上黄在线观看| 韩日精品视频一区| 欧美中文字幕在线| 国产精品国产三级国产传播| 高清精品xnxxcom| 在线观看视频91| 成年人视频大全| 免费在线黄色网址| 福利一区二区在线| 国产精品专区一| 日本中文字幕免费| 色喇叭免费久久综合| 亚洲精品电影网站| 亚洲一区精品视频在线观看| 日韩精品av| 亚洲激情一二三区| 亚洲欧美日韩在线综合| 视频在线不卡| 国产不卡视频在线播放| 国产精品视频1区| 日韩大片免费在线观看| 91精品成人| 亚洲午夜精品久久久久久性色| 免费看91视频| 亚洲一区二区av| 日本久久精品电影| 99在线精品免费视频| 成人看av片| 中文乱码免费一区二区| 久久伦理网站| 人妻无码一区二区三区久久99| 久久国产生活片100| 日本精品视频在线观看| 日韩乱码一区二区| 国产精品magnet| 精品国产拍在线观看| 日本少妇xxxxx| 精品欧美午夜寂寞影院| 日韩欧美中文字幕制服| 色呦色呦色精品| 欧美激情喷水| 日韩欧美精品中文字幕| 黄色影院一级片| 免费一二一二在线视频| 亚洲国产日韩a在线播放| 麻豆视频传媒入口| 亚洲丝袜精品| 亚洲精品国久久99热| 四虎永久免费网站| 最新超碰在线| 亚洲精选免费视频| 精品免费久久久久久久| av毛片在线| 一个色妞综合视频在线观看| 日本国产中文字幕| 欧美性爽视频| 午夜精品在线视频一区| 国产成人无码a区在线观看视频| 波多野结衣在线观看| 午夜影院久久久| 日本午夜激情视频| 热色播在线视频| 色综合激情五月| 一本久道中文无码字幕av| 亚洲高清黄色| 欧美三级一区二区| 久久精品亚洲天堂| 亚洲高清在线一区| 亚洲精品98久久久久久中文字幕| 亚洲一区二区三区无码久久| 伊人成综合网伊人222| 亚洲视频欧洲视频| 九九热久久免费视频| 911精品美国片911久久久 | 亚洲免费在线播放视频| 高清亚洲高清| 日韩一区二区影院| 国产一级免费片| 男男gay无套免费视频欧美| 国产一区二区动漫| 国产精品夜夜夜爽阿娇| 欧美午夜免费影院| 国产z一区二区三区| 国产精品老熟女视频一区二区| 国产精品99久久久久久宅男| 激情视频一区二区| 成人免费高清在线播放| 一区二区三区影院| 国产日韩一区二区在线观看| 欧美黑粗硬大| 亚洲国产高清福利视频| 人妻视频一区二区| 欧美在线网址| 日本人成精品视频在线| 国产免费福利视频| 91丨porny丨户外露出| 一区二区日本| 在线观看爽视频| 91麻豆精品国产91久久久久| 91视频在线免费| 999精品在线| 欧美在线视频网站| av手机免费看| 日本一区二区三级电影在线观看 | 亚洲精品影院| 日韩av综合在线| 热久久一区二区| 成人av免费在线看| 风间由美一区| 亚洲国产成人高清精品| 99sesese| 免费av网站在线| 中文字幕亚洲精品乱码| 5566成人精品视频免费| 国产免费视频一区二区三区| 国产亚洲一区二区三区在线观看| 欧美黄网在线观看| 高清av一区二区三区| 亚洲大胆人体在线| 日本天堂中文字幕| 免费精品视频在线| 久久久综合香蕉尹人综合网| 青青在线视频| 欧美另类变人与禽xxxxx| 大又大又粗又硬又爽少妇毛片| 国产综合网站| 91精品综合久久久久久五月天| 青青青手机在线视频观看| 亚洲综合激情另类小说区| 在线不卡一区二区三区| 日本一区二区免费高清| 日本电影亚洲天堂| 婷婷av一区二区三区| 夜夜精品视频一区二区| 中文字幕乱妇无码av在线| 欧美电影《轻佻寡妇》| 国产精品久久久久久久久久东京| 视频一区二区三区在线看免费看| 亚洲午夜久久久久久久久久久| 在线不卡一区二区三区| 国产精品久久久久久麻豆一区软件| 热久久免费视频精品| 手机福利小视频在线播放| 黑人巨大精品欧美一区二区| 亚洲久久久久久| 99成人免费视频| 九九久久99| 手机在线理论片| 日韩电影在线观看中文字幕| 青青国产在线观看| 91视频一区二区三区| 日韩美女爱爱视频| 国产毛片精品| 欧美一区二区三区……| 人操人视频在线观看| 在线一区二区三区做爰视频网站| 91视频免费观看网站| 玖玖玖国产精品| 亚洲精品第一区二区三区| 成人国产精选| 麻豆国产精品va在线观看不卡 | 国产精品日本欧美一区二区三区| 精品视频高清无人区区二区三区| 美女视频在线免费| 亚洲天堂精品在线| 伊人网av在线| 亚洲免费电影在线| 亚洲日本久久久| 国产美女一区| 亚洲精品久久久久久一区二区| 色狠狠一区二区三区| 欧美精品做受xxx性少妇| 欧美一区二区三区成人片在线| 欧美日韩免费观看中文| 最近中文字幕在线mv视频在线| 久久精品国产秦先生| 草草草视频在线观看| 丝袜美腿综合| 成人精品网站在线观看| 2021天堂中文幕一二区在线观| 亚洲欧美另类人妖| 亚洲一卡二卡在线观看| 亚洲午夜av在线| 中文字幕精品久久久| 日韩va亚洲va欧美va久久| 做爰高潮hd色即是空| 加勒比视频一区| 国产精品免费观看在线| 日本性爱视频在线观看| 亚洲天堂av在线免费观看| 国产强伦人妻毛片| 欧美日韩一区二区在线播放| 国产探花在线视频| av中文字幕在线不卡| 国产成人手机视频| 亚洲私拍自拍| 一区二区欧美日韩| 羞羞答答一区二区| 91成人免费观看| 欧美xxxx做受欧美护士| 国模视频一区二区| 日本不卡三区| 亚洲欧美激情精品一区二区| 亚洲精品无遮挡| 欧美三级韩国三级日本三斤| 国产极品美女高潮无套嗷嗷叫酒店| 国产片一区二区三区| 精品少妇人妻av一区二区三区| 久久精品免费观看| av动漫在线观看| 国产主播精品| 欧美少妇在线观看| 日韩成人激情| 免费试看一区| 乱中年女人伦av一区二区| 国产日本欧美视频| 欧美性suv| 欧美一级成年大片在线观看| 黄页网站在线| 欧美精品免费播放| 免费av在线网站| 中文字幕久久亚洲| 免费黄色在线视频网站| 亚洲黄色在线看| 精品人妻无码一区二区色欲产成人 | 日韩精品成人| 成人免费黄色网| 国产精品久久乐| 国产福利成人在线| 中文字幕一区久| 2019中文字幕免费视频| 91高清视频在线观看| 欧美激情高清视频| 色www永久免费视频首页在线 | 午夜视频久久久| 久久99国产成人小视频| 欧美日韩成人一区二区三区| 最新国产精品视频| 老牛影视免费一区二区| 伊人久久大香线蕉综合网站| 欧美大香线蕉线伊人久久| 秋霞综合在线视频| 女人一区二区三区| 女人av一区| 亚洲狠狠婷婷综合久久久| 青草国产精品| 9999在线观看| 一区二区三区在线电影| 免费网站在线观看视频| 亚洲午夜91| www黄色日本| 性欧美xxxx大乳国产app| 五月婷婷深爱五月| 免费在线观看一区二区三区| 亚洲18在线看污www麻豆| 国产自产v一区二区三区c| 青青草原播放器| 成人午夜在线播放| 日韩av一二区| 国产三级精品在线| 手机在线中文字幕| 亚洲国产美国国产综合一区二区| 久久视频免费在线观看| 欧美日韩另类视频| 中文字字幕在线观看| 555夜色666亚洲国产免| 韩国中文字幕hd久久精品| 亚洲国产日韩一区| 高清在线观看av| 久久婷婷国产麻豆91天堂| 69av成人| 国产精品老牛影院在线观看| 国产精品一区二区美女视频免费看 | 缅甸午夜性猛交xxxx| 久久久综合网| 永久免费黄色片| www.亚洲国产| www.涩涩爱| 亚洲午夜激情网站| 中文文字幕一区二区三三| 日韩精品一区二区三区四区视频| 色视频在线观看| 久久精品中文字幕电影| 华人av在线| 成人免费视频网址| 欧美高清视频看片在线观看| 一区二区欧美日韩| 一区二区高清| 日本国产一级片| 91女神在线视频| 成人免费视频网站入口::| 欧美性xxxx极品高清hd直播| 国产视频第二页| 亚洲三级黄色在线观看| 在线观看wwwxxxx| 国产精品观看在线亚洲人成网| 中文字幕一区日韩精品 | 久久久久国产精品| 久久网站免费视频| 国产精品一区二区在线播放 | 亚洲另类在线制服丝袜| 黄色一级视频免费看| 欧美成人免费网站| 91精品国产91久久久久游泳池 | 久久国产精品99国产精| 日韩精品99| 精品乱子伦一区二区三区| 亚洲成人tv| 色多多视频在线播放| 不卡av电影在线播放| 日本老熟俱乐部h0930| 欧美午夜精品一区| 日本在线一二三| 韩国三级日本三级少妇99| 精品三级久久久| 亚洲午夜精品国产| 丝袜亚洲精品中文字幕一区| 国产精品无码一区二区三| 亚洲综合偷拍欧美一区色| 97超碰人人模人人人爽人人爱| 亚洲天天在线日亚洲洲精| 色综合桃花网| 精品一区二区三区日本| 国内激情久久| 亚洲av无码久久精品色欲| 亚洲三级在线免费观看| 一级黄色短视频| 三级精品视频久久久久| 日本一区免费网站| 日本在线观看一区二区| 裸体一区二区| a毛片毛片av永久免费| 黑人与娇小精品av专区| 天天操天天射天天| 免费国产成人看片在线| 久久国产88| 无遮挡aaaaa大片免费看| 精品久久久久久久久久久| 色噜噜在线播放| 国外成人在线直播| 欧美绝顶高潮抽搐喷水合集| 黄色www网站| 99久久国产综合精品女不卡| 日产精品久久久久| 亚洲成人三级在线| 91老司机福利在线| 久久精品国产99精品国产亚洲性色| 亚洲免费激情| 美女又爽又黄视频毛茸茸| 欧美性高跟鞋xxxxhd| 免费一级毛片在线观看| 国产成人精品在线| 不卡中文字幕| √天堂资源在线| 亚洲图片自拍偷拍| 日本wwwxxxx| 日韩美女福利视频| 国内精品久久久久久99蜜桃| 亚洲成人av免费看| 亚洲人成影院在线观看| 一级黄色录像大片| 色综合久久天天综线观看| 久久99精品久久久久久欧洲站| 92看片淫黄大片一级| 日本一区二区久久| 国产精品高潮呻吟AV无码| 欧美日韩成人免费| 亚洲另类av| 日韩欧美亚洲另类| 亚洲成人资源网| porn视频在线观看| 亚洲a一级视频| 在线亚洲伦理| 99国产精品无码| 精品国内二区三区| 免费成人美女女| 乱子伦一区二区| 久久无码av三级| 国产情侣一区二区| 97国产在线观看| 日韩精品诱惑一区?区三区| 欧美性猛交乱大交| 欧美日韩一区二区精品| 麻豆系列在线观看| 久久精品成人一区二区三区蜜臀| 麻豆精品视频在线| 日韩av免费网址| 色多多国产成人永久免费网站 | 免费成人在线电影| 五月天久久综合网| 成人av网站在线| 在线观看免费中文字幕| 97视频色精品| 亚洲欧洲日韩| 日本综合在线观看| 亚洲激情免费观看|