created_at
updated_at
tags
toc

CSS Layout API で Masonry Layout

Intro

Pinterest でおなじみの Masonry Layout を CSS の標準にする作業と実装が進んでいる。

Masonry Layout

以下のように画像を敷き詰めるタイルレイアウトのことを Masonry (石工やレンガ造りの意味らしい) Layout という。

高さの違う画像が縦 3 列に敷き詰められたレイアウト

上の例の場合は、 Height が不揃いの画像を並べる上で、左から敷き詰め、折り返したら既にある画像の高さに合わせて二列目が始まるというロジックになる。

これを実現するには、割と複雑な CSS を書く必要があり、様々なサイトで CSS ライブラリや、 Grid などを用いて再現する方法が紹介されている。

これをそのまま CSS の標準にする作業が Layout API の文脈で行われており、既に一部が(主に Firefox で)実装されている。

grid: masonry;

仕様は以下だ。

従来の CSS Grid は、縦横が揃った Grid を展開し、そこに対して要素を割り当てるのが基本だが、それでは縦が揃わないため Masonry は実現できない。

そこで、 grid-template-rows / grid-template-columnsmasonry を追加し、これを指定すると Masonry レイアウトが実現できるようになる。省略すると grid: masonry / ${column} になるため、 column に repeat などを指定すれば Pinterest のようなレイアウトが実現できる。

3 列の Masonry Layout は以下だ。

<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