CSS Layout API で Masonry Layout
Intro
Pinterest でおなじみの Masonry Layout を CSS の標準にする作業と実装が進んでいる。
以下のように画像を敷き詰めるタイルレイアウトのことを Masonry (石工やレンガ造りの意味らしい) Layout という。
上の例の場合は、 Height が不揃いの画像を並べる上で、左から敷き詰め、折り返したら既にある画像の高さに合わせて二列目が始まるというロジックになる。
これを実現するには、割と複雑な CSS を書く必要があり、様々なサイトで CSS ライブラリや、 Grid などを用いて再現する方法が紹介されている。
これをそのまま CSS の標準にする作業が Layout API の文脈で行われており、既に一部が(主に Firefox で)実装されている。
仕様は以下だ。
従来の CSS Grid は、縦横が揃った Grid を展開し、そこに対して要素を割り当てるのが基本だが、それでは縦が揃わないため Masonry は実現できない。
そこで、 3 列の Masonry Layout は以下だ。
敷き詰めるためのアルゴリズムは仕様で決まっている。
デフォルトでは、敷き詰める際に一番余白が空いているところに画像が挿入される。
これを制御するプロパティとして 他の値もあるがまだ定義が明示されていないようだ。このあたりのアルゴリズムは要件によって多様だと思われるため、仕様の策定とともに変わる可能性は高いだろう。
Masonry Layout
grid: masonry;
grid-template-rows
/ grid-template-columns
へ masonry
を追加し、これを指定すると Masonry レイアウトが実現できるようになる。省略すると grid: masonry / ${column}
になるため、 column に repeat などを指定すれば Pinterest のようなレイアウトが実現できる。
<style>
.grid {
display: inline-grid;
grid: masonry / repeat(3, auto);
border: 1px solid;
gap: 1vw;
masonry-auto-flow: pack;
width: 32vw;
}
img {
width: 10vw;
}
</style>
<div class=masonry>
<img>
<img>
<img>
...
</div>
masonry-auto-flow
masonry-auto-flow
が定義されており、next
にすると画像の HTML 上での出現順に積み上げるようにすることもできる。
masonry-auto-flow: pack;
masonry-auto-flow: next;
DEMO
動作するデモを以下に用意した。現状 Firefox Nightly でしか動作を確認してない。
(サポート状況は WPT 参照)
Resources
-
Spec
- CSS Grid Layout Module Level 3
-
Explainer
- css-houdini-drafts/EXPLAINER.md at master - w3c/css-houdini-drafts
- Requirements Doc
- Mozilla Standard Position
- Webkit Position
-
TAG Design Review
- CSS Layout API - Issue #224 - w3ctag/design-reviews
-
Intents
- Intent to Prototype: CSS Masonry layout
- Intent to Implement: CSS Layout API
- Chrome Platform Status
-
WPT(Web Platform Test)
- web-platform-tests dashboard
- DEMO
- Blog
- Presentation
-
Issues
- [css-grid] Masonry layout - Issue #4650 - w3c/csswg-drafts
- Other