data:image/s3,"s3://crabby-images/3ee92/3ee92f96145a5d36a6d881b0cdf0efef1af050fd" alt="パソ君"
・CSSを使って上下や左右中央寄せする方法は?
こんな疑問にお答えします。
デザインカンプによっては、上下や左右に中央寄せになっていることありますよね。
コーダーなら一度は実装したことあるはず。
ただ実装方法が色々あり、迷ってしまうんですよね。
そこで今回、中央寄せする方法をまとめてみました。
data:image/s3,"s3://crabby-images/17371/173713cf8bd4265b79ed3f9efd228bdd35c0b78f" alt="ジト"
覚えておくべし!
ということで、この記事では「上下・左右に中央寄せする方法」について解説していきます!
上下・左右に中央寄せする方法
目次
【CSS】上下・左右に中央寄せする方法【Gridなら2行】
上下・左右に中央寄席する方法は主にこちら↓
- 左右:「text-align」
- 左右:「margin」
- 上下:「line-height」
- 上下:「vertical-align」
- 上下左右:「position+margin」
- 上下左右:「position+transform」
- 上下左右:「flex」
- 上下左右:「grid」
順に見ていきましょう。
子要素の文章や画像を、左右中央寄せしたいなら「text-align: center」を使います。
data:image/s3,"s3://crabby-images/7c0e3/7c0e376f47e5dbeb2f59d8130ee2f3031f48e1e6" alt=""
text-align: center;
要素自体を中央寄せしたい場合は、左右のmarginをautoにします。
ただ要素の横幅指定が必要です。(今回は横幅50%に指定)
data:image/s3,"s3://crabby-images/837b8/837b8a2d155389905ee05cda8a1dcfbd6299e813" alt=""
<div class="box">
<p class="txt">ここに文章が入ります。</p>
</div>
.txt {
width: 50%;
margin-right: auto;
margin-left: auto;
}
「line-height」を使い、縦長さと行間を等しくすることで上下中央寄せが可能です。
data:image/s3,"s3://crabby-images/99861/99861c4ba7010bb1c26df6cfe46f7cf2484581a0" alt=""
<div class="box">
<p class="txt">ここに文章が入ります。</p>
</div>
.box {
height: 100px;
}
.txt {
line-height: 100px;
}
ただし「高さが決まっている」+「テキストが1行のみ」のときしか、有効な方法ではありません。
「vertical-align:middle」を使うことで、上下中央寄せが可能です。
data:image/s3,"s3://crabby-images/6300b/6300bd46621025eb3e50a881021f2b190b1eab03" alt=""
<div class="box">
<p class="txt">ここに文章が入ります。</p>
</div>
.box {
display: table;
}
.txt {
display: table-cell;
vertical-align: middle;
}
ただし「vertical-align」が効くのは、インライン要素またはテーブルセルです。
そのため「display: table-cell;」を指定して、効くように指定しています。
「position: absolute」と「margin」の特性を生かして、上下左右中央寄せすることが可能です。
data:image/s3,"s3://crabby-images/7eb30/7eb300ce7462970eff8a4ee231d7f57be1fec0cd" alt=""
<div class="box">
<p class="txt">ここに文章が入ります。</p>
</div>
.box {
height: 300px;
position: relative;
}
.txt {
width: 50%;
height: 50px;
position: absolute;
top: 0;
right: 0;
left: 0;
bottom: 0;
margin: auto;
}
要素の高さを指定する必要があるのがデメリットですね。
これは結構主流ではないでしょうか。
「absolute」と「transform」を用いて上下左右中央寄せする方法です。
data:image/s3,"s3://crabby-images/c20ab/c20ab1349726fec49edf0a9eb0a7476245660477" alt=""
<div class="box">
<p class="txt">ここに文章が入ります。</p>
</div>
.box {
height: 300px;
position: relative;
}
.txt {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%,-50%);
}
中の要素の縦幅を指定する必要がないのが良いですね。
レスポンシブ対応もしやすいです。
シンプルでかなり楽なやり方です。
「display: flex」+「justify-content: center」+「align-items: center」を用いて上下左右中央寄せする方法。
data:image/s3,"s3://crabby-images/54a99/54a9930dfe1e62b6456022e50b991ca1c81bbd07" alt=""
<div class="box">
<p class="txt">ここに文章が入ります。</p>
</div>
.box {
display: flex;
justify-content: center;
align-items: center;
}
これは最新、かつ最短コードでできる上下左右中央寄せです。
「display: grid」+「place-items: center」のたった2行を使うだけ。
data:image/s3,"s3://crabby-images/57c46/57c461c5d492f08bddba81ed0e7088a0bb15891e" alt=""
<div class="box">
<p class="txt">ここに文章が入ります。</p>
</div>
.box {
display: grid;
place-items: center;
}
「place-items」を使うことで、本来2行必要なコードを1行にまとめることができます。
place-items: center;
// ↓
justify-items: center;
align-items: center;
【最新】CSSで上下・左右に中央寄せする方法8選【Gridなら2行】:まとめ
- 左右:「text-align」
- 左右:「margin」
- 上下:「line-height」
- 上下:「vertical-align」
- 上下左右:「position+margin」
- 上下左右:「position+transform」
- 上下左右:「flex」
- 上下左右:「grid」
data:image/s3,"s3://crabby-images/17371/173713cf8bd4265b79ed3f9efd228bdd35c0b78f" alt="ジト"
中央寄せしたい場合は試してみてね!