皆様お疲れ様です!るーぷの2年目コーダー、三木です。
今回は、
data:image/s3,"s3://crabby-images/47185/47185814bb0ebfb8048e0c9ba6ff82ed8495fcbe" alt=""
例えばこの画像で言うと、
「1件だけお知らせのタイトルが入ります。1件だけ……」のところは
「text-align: center;」(行揃え:中央寄せ)にしないほうがいいかも。
というお話をしていきます。
「text-align: center;」がマズイ理由
画面幅が変わったり、文字数が変わるといずれ折り返しが発生します。
折り返して2行目になった文字も中央に寄るので、
コンテンツの位置によっては読みづらくなったり見栄えが悪くなります。
(見た目で分かりやすくするため、文字の領域の背景色を変更しています。)
data:image/s3,"s3://crabby-images/cc457/cc457818450b65972417e6883cf18c6b97d38095" alt=""
↓文字数が変わると(画面幅が狭まると)
data:image/s3,"s3://crabby-images/53a94/53a94fdfdc5ebe5af8ffc5c79ce894e325302236" alt=""
こうなるのを防ぎたいので、文字はデフォルトの「左寄せ」のまま、
文字数が少ない時は中央に配置される状態を目指します。
目指す挙動↓
data:image/s3,"s3://crabby-images/2eb84/2eb84be069ae7323dcc262223bec55c786a52007" alt=""
↓文字数が増えると(画面幅が狭まると)
data:image/s3,"s3://crabby-images/4c1b9/4c1b9809c3d109efaf819fed8dc1aba30ee9694f" alt=""
「text-align: center;」以外で文字を中央に配置するCSS
おすすめ度:高
「width: fit-content;」+「margin-inline: auto;」
おすすめ度:中
「display: flex;」または「display: grid;」+「margin-inline: auto;」
おすすめ度:低(文字の配置調整での使用はおすすめできません)
「position: absolute;」+「left: 50%;」+「transform: translateX(-50%);」
ひとつずつ解説します。
「width: fit-content;」+「margin-inline: auto;」
HTML
<p><a href=””>1回だけお知らせのタイトルが入ります。1回だけお知らせのタイトルが入ります。1回だけお知らせのタイトルが入ります。</a></p>
</div>
CSS
padding: 2rem 5%;
background-color: #dadada;
}
.news_wrapper p{
font-size: 1.8rem;
font-weight: 700;
background-color: #aaa;
width: fit-content;
margin-inline: auto;
}
pタグに「width: fit-content;」と「margin-inline: auto;」をあてます。
・「width: fit-content;」←中のコンテンツに幅を合わせる。
・「margin-inline: auto;」←左右余白をいっぱいに。
(「width: fit-content;」の代わりに「display: inline-block;」でも、コンテンツに幅を合わせられます。)
data:image/s3,"s3://crabby-images/70c9f/70c9ff3c88bb24077b3c5b9e62271aa4d7555564" alt=""
↓画面幅を縮めると
data:image/s3,"s3://crabby-images/1eefd/1eefd33f4ce665e80bea948a9e4daaa3c69e7454" alt=""
「display: flex;」または「display: grid;」+「margin-inline: auto;」
HTML
<p><a href=””>1回だけお知らせのタイトルが入ります。1回だけお知らせのタイトルが入ります。1回だけお知らせのタイトルが入ります。</a></p>
</div>
CSS
padding: 2rem 5%;
background-color: #dadada;
display: flex;
}
.news_wrapper p{
font-size: 1.8rem;
font-weight: 700;
background-color: #aaa;
margin-inline: auto;
}
.news_wrapperに「display: flex;」または「display: grid;」を、
pタグに「margin-inline: auto;」をあてます。
・「display: flex;」←中の要素を横並びにする。
・「display: grid;」←格子状にブロックで区切り、中の要素をレイアウトする。
「width: fit-content;」+「margin-inline: auto;」と同じ挙動になりますが、
もしお知らせが2つ必要になった場合を考えると、少々おすすめ度が下がります。
data:image/s3,"s3://crabby-images/e7c00/e7c008344b8e2107c5265881189d5d763726020e" alt=""
(要素が二つ以上になると横並びになってしまいます。回避するには更にdivタグで囲うなどの対策が必要になります。)
「position: absolute;」+「left: 50%;」+「transform: translateX(-50%);」
HTML
<p><a href=””>1回だけお知らせのタイトルが入ります。1回だけお知らせのタイトルが入ります。1回だけお知らせのタイトルが入ります。</a></p>
</div>
CSS
padding: 2rem 5%;
background-color: #dadada;
position: relative;
}
.news_wrapper p{
font-size: 1.8rem;
font-weight: 700;
background-color: #aaa;
position: absolute;
left: 50%;
transform: translateX(-50%);
}
(.news_wrapperに「position: relative;」を、)
pタグに「position: absolute;」「left: 50%;」「transform: translateX(-50%);」をあてます。
・「position: absolute;」←親要素を基準に絶対配置を指定。(かなり自由な配置が可能。)
・「left: 50%;」←親要素を基準に左から50%の位置に。
・「transform: translateX(-50%);」←自身の横幅を基準に50%左へ移動。
おすすめできない理由は以下の画像をご覧ください。
CSS指定前。
data:image/s3,"s3://crabby-images/d0393/d0393d4bd5342ec15a906705b7fbf2fecba77b10" alt=""
↓「position: absolute;」を指定。
data:image/s3,"s3://crabby-images/1fe4c/1fe4c16d125987edc7f2164eebb70f93f73e52a6" alt=""
なんと「.news_wrapper」の高さが変わってしまいます。
↓「left: 50%;」を指定。
data:image/s3,"s3://crabby-images/6ed26/6ed26a09f9d98c2080efc9a728ba2b427a41afed" alt=""
移動した分、文字の折り返しが発生してしまいます。
↓「transform: translateX(-50%);」を指定。
data:image/s3,"s3://crabby-images/df21b/df21b0c0f1fe8a939e2e99e39ae5f81c0e904f25" alt=""
折り返した状態のまま位置を移動してしまいます。
以上の挙動から、文字の配置調整にはおすすめできません。
おわりに
さて、「text-align: center;」以外で文字を中央寄せよせする方法を3点ご紹介しましたが、
基本的には一つ目に紹介した
「width: fit-content;」+「margin-inline: auto;」
が一番使い勝手が良いので、基本的にはこの方法だけでも覚えて使っていければ良いと思います。
「position: absolute;」「left: 50%;」「transform: translateX(-50%);」のように
「position: absolute;」を使えば簡単に位置の移動はできますが、
画面幅を変えると他の要素に被ってしまったり…など思いがけない挙動をしたり、
CSSアニメーションの弊害になったり、良くないことも多いので、
「position: absolute;」での位置調整は、個人的には極力避けたいです。
以上です!