本記事では、display:flexで横並びになっている一番先頭のアイテムだけを左寄せする方法について解説しています。
HTML/CSSの学習におすすめ参考書
1冊ですべて身につくHTML&CSSとWebデザイン入門講座
先輩くん
Amazon Kindle Unlimitedに登録すると、月額980円で読み放題だからオススメだよ!
後輩ちゃん
初回30日間は無料だから、まだ登録したことのない人はぜひ試してみてね!
綺麗なコードが書けるようになる!
リーダブルコード-より良いコードを書くためのシンプルで実践的なテクニック
先輩くん
より良いコードを書きたい人におすすめの本だよ!
後輩ちゃん
10以上前の書籍ですが、内容は今でも役に立つものばかりです!
marginを使う
display:flexは、flex-wrapやflex-directionなどの特別なプロパティを持っているため、先頭のみ左寄せするプロパティがあると思った方は多いと思います。(私も始めの頃は専用のプロパティがあるものだと。。)
しかし、そのようなプロパティはなく皆さんが使い慣れているmarginプロパティを活用することで先頭のみ左寄せすることが可能です。
使い方はとても簡単で、先頭のアイテムに対してmargin-right: auto;を設定するだけです。
/* 一番最初のアイテム */
.first-item{
margin-right: auto;
}
先輩くん
試しに先頭のアイテムにmargin-right:auto;を設定して表示確認してみましょう!
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" href="style.css" />
</head>
<body>
<div class="content">
<div class="content__item">1番目</div>
<div class="content__item">2番目</div>
<div class="content__item">3番目</div>
<div class="content__item">4番目</div>
<div class="content__item">5番目</div>
</div>
</body>
</html>
.content {
display: flex;
}
.content__item {
display: flex;
align-items: center;
justify-content: center;
width: 150px;
height: 150px;
}
.content__item:nth-of-type(1) {
margin-right: auto; /* 先頭のみ設定! */
background-color: forestgreen;
}
.content__item:nth-of-type(2) {
background-color: darkgoldenrod;
}
.content__item:nth-of-type(3) {
background-color: fuchsia;
}
.content__item:nth-of-type(4) {
background-color: aquamarine;
}
.content__item:nth-of-type(5) {
background-color: brown;
}

先輩くん
先頭のアイテムだけ左寄せになっていますね!