【HTML&CSS】ギャラリーサイトを作る(グリッドレイアウト)
data:image/s3,"s3://crabby-images/c4116/c4116797ea98ea854c2e63445e26132e43700a04" alt=""
data:image/s3,"s3://crabby-images/033c8/033c883ba86f7d2724f77c4f4377b9f81f316d2d" alt=""
ギャラリーのようなサイトを作りたいです。
data:image/s3,"s3://crabby-images/fc1f7/fc1f7ed08d522d059fc6572ae0a39d384a42c531" alt=""
data:image/s3,"s3://crabby-images/3069e/3069ec11fd94c636e19a3a036c1b3742c19443b3" alt=""
今回はこのようなレイアウトができるグリッドレイアウトについてみていきましょう。
gridレイアウト
gridレイアウトは列と行で格子状に要素を並べていくレイアウトです。
デザインがしやすくギャラリーサイトのようなサイトに利用されます。
グリッドレイアウト(基本)
【HTML】
タイル状に並べたい要素を親要素(containerというクラス名を付けました)で囲みます。
data:image/s3,"s3://crabby-images/d4d17/d4d17fe5f8b26a1f413392fd3fdc25bb444ba916" alt=""
<body>
<section class="container">
<div class="item1">1</div>
<div class="item2">2</div>
<div class="item3">3</div>
<div class="item4">4</div>
<div class="item5">5</div>
<div class="item6">6</div>
<div class="item7">7</div>
<div class="item8">8</div>
<div class="item9">9</div>
</section>
</body>
【CSS】
親要素に『display:grid;』をかけます。
『grid-template-columns』で必要なグリッドアイテムの数だけ幅を指定します。
今回は『300px 300px 300px』と3列です。
次に『grid-template-rows』で高さの指定をします。
data:image/s3,"s3://crabby-images/1d3f5/1d3f5a47fbbfb6df78b9c3d92d92a1538e680db0" alt=""
.container {
display: grid;
grid-template-columns: 300px 300px 300px;
grid-template-rows: 200px 200px 200px;
}
するとこんな感じ。
分かりやすいように『background-color』を付けています。
data:image/s3,"s3://crabby-images/cee15/cee1547bc005b993e142efbe45808bcbf92e1456" alt=""
幅指定を増やす
幅の指定を5個してみます
data:image/s3,"s3://crabby-images/ae0ea/ae0eada0c745da8ae709e0a1b64b36701b30e0a0" alt=""
.container {
display: grid;
grid-template-columns: 200px 200px 200px 200px 200px;
grid-template-rows: 200px 200px 200px;
}
すると5列になります
data:image/s3,"s3://crabby-images/ab1ef/ab1efbe7b0d9326f3fbc6257142c832f5c8ed635" alt=""
要素の間に余白をつける
列と列行と行の余白は『gap』で指定します。
data:image/s3,"s3://crabby-images/84348/84348456598b1d1d5b15806233e324e1a9b6aa2d" alt=""
.container {
display: grid;
grid-template-columns: 300px 300px 300px;
grid-template-rows: 300px 300px 300px;
gap: 10px;
}
10px付けてみました。
data:image/s3,"s3://crabby-images/737d3/737d3ed2b6c43ba15550fbce1dd14128fb48567e" alt=""
比率で指定
今までpxで指定していましたが、『1fr 1fr 1fr』とすると比率で指定する事ができます。
data:image/s3,"s3://crabby-images/e4e88/e4e88339732cb1eabf2718fdf4b69143b3f57669" alt=""
.container {
display: grid;
grid-template-columns: 1fr 1fr 1fr;
grid-template-rows: 100px 100px 100px;
}
1:1:1の比率になる。
data:image/s3,"s3://crabby-images/f8de1/f8de173ec5ff0896b0353c443cf1a01f521bdb49" alt=""
『1fr 2fr 1fr』にすると『1:2:1』つまり『25%:50%:25%』になります。
data:image/s3,"s3://crabby-images/01648/01648ccdb30974ec25899efd2ccdf8180fbd15dc" alt=""
.container {
display: grid;
grid-template-columns: 1fr 2fr 1fr;
grid-template-rows: 100px 100px 100px;
}
data:image/s3,"s3://crabby-images/66585/665853d7eea2e594d113339de6dcb9a3ebb2e052" alt=""
応用
『grid-template-areas』を使うともっと自由な表現ができます。
親要素に『grid-template-areas:』
data:image/s3,"s3://crabby-images/938fe/938fe15a80445ab2d9c20aa6d768f818750646e6" alt=""
それぞれの子要素全てに対応する名前を『grid-area:』で付けます。
『grid-area:item1;』のようにします。
並べるとこのように要素を並べることができます。
data:image/s3,"s3://crabby-images/326cb/326cb5a2ac2e494da3e5bf7568d1669e4d32bbed" alt=""
するとこのように自由な並べ方ができます。
data:image/s3,"s3://crabby-images/86ad8/86ad85e989e556714d45fc7b6c9ff55bb68c7054" alt=""
data:image/s3,"s3://crabby-images/eb9d0/eb9d04d31a012f3fda1c9aaec1587532f2b3c5dc" alt=""
.container {
display: grid;
grid-template-columns: 1fr 1fr 1fr ;/*列の数だけ必要*/
grid-template-rows: 100px 100px 100px 100px 100px;/*行の数だけ必要*/
grid-template-areas:
"item1 item1 item1"
"item2 item2 item3"
"item4 item4 item3"
"item5 item6 item7"
"item5 item8 item9";
}
このように簡単にタイル状のレイアウトをすることができます。
**********
displayblockやgridについて初心者にもわかりやすく説明してくれている本です。
基本的なことがこの1冊にすべて詰まっていてとてもおすすめの1冊です。
**********
ギャラリーに動きをつけたいならこちらの「動くWebデザインアイデア帳」がおすすめです。
動きのあるパーツはこの1冊でほとんどできます!
同じカテゴリの記事一覧へ