【CSS】line-heightとは?line-height:1px;の使い方
data:image/s3,"s3://crabby-images/a261b/a261b52a79781c7f11f5e607bc13aec0c48769c0" alt=""
data:image/s3,"s3://crabby-images/033c8/033c883ba86f7d2724f77c4f4377b9f81f316d2d" alt=""
CSSのline-heightとは何でしょう?
line-height:1px;とはどんな時に使うのでしょうか?
line-heightとは
line-heightとは行の高さを指定するプロパティです。
例えば下のようにフォントサイズ10pxのテキストに
「line-height:30px;」を指定した場合テキストの上下に10pxずつの余白ができます。
行(line-height)の中でテキストは上下中央に表示されます。
data:image/s3,"s3://crabby-images/ab969/ab969bf3e0036fa26f21fc3f29f88d5b92ce79c9" alt=""
line-heightプロパティは子要素に継承されるため、bodyに指定しておけばページ全体を管理できるため便利です。
line-heightの単位
line-heightプロパティで指定できる単位は「normal(初期値)」、「%」、「px」などがあります。
line-heightはどのくらいで指定すればよいのか?
フォントサイズにもよりますが一般的に「line-height: 1.5;」~「line-height: 2;」くらいが適当とされています。
data:image/s3,"s3://crabby-images/5f5da/5f5daca9d0b68389fd6332b52d0795f135f33288" alt=""
h1で「「line-height: 2;」に指定してみました。ちょうどよいですね。
data:image/s3,"s3://crabby-images/ca5bd/ca5bd280b93f875239532f22899f5fc9ca2738a2" alt=""
pタグでもちょうど良さそうですね。
好みにもよりますが1.5から2くらいでちょうど良さそうです。
line-height:1px;とは
line-height:1px;と指定してあるものを見かけると思います。
このようによくあるヘッダー。
<h1>のロゴと<li>のナビゲーションを横並びにしました。
<header id="header" class="wrapper">
<h1 class="site-title"><img src="img/logo1.png" alt=""></h1>
<nav>
<ul>
<li>HOME</li>
<li>CONTACT</li>
</ul>
</nav>
</header>
data:image/s3,"s3://crabby-images/e2e03/e2e03fda7334b16ab249cf7e8631f63058be99f8" alt=""
ところがデベロッパーツールで見るとこのように「logo」マークの下には変な余白が入っています。
「align-items: center;」もあてて縦方向中央に指定しているにも関わらず、その余白のせいで「nav」より上に表示されてしまっています。
#header {
display: flex;
justify-content: space-between;
align-items: center;
margin: 0 auto;
}
data:image/s3,"s3://crabby-images/d1ac4/d1ac48aee206bf70cae111f1460359f8a9b329fe" alt=""
line-height:1px;を指定する
そこで「line-height:1px;」と<h1>の高さよりも小さい値の「line-height」を指定することで<h1>の上下の余白が消えて<nav>の高さと揃えることができました。
.site-title {
width: 120px;
line-height:1px;
padding: 10px 0;
}
data:image/s3,"s3://crabby-images/521cc/521cc7dc909bf5cabe64722805333e7dfb483462" alt=""
テキストを上下中央にする
先程「line-height」で指定するとテキストは中央に配置できるとお伝えしました。
ですから例えばこのようにボックスの中でテキストを中央にしたいという時
data:image/s3,"s3://crabby-images/62736/627363398e926952863e59911e51bfe00ffd6b97" alt=""
「line-height」ボックスの高さを指定すればちょうど真ん中にテキストが表示されます。
今回の場合は赤いボックスの高さが200pxなので
data:image/s3,"s3://crabby-images/e1d66/e1d6638916748c2afce15548f30f28f79236c39f" alt=""
「line-height: 200px;」と指定するとテキストはボックスの上下中央に表示されます。
.red {
width: 200px;
height: 200px;
background-color: red;
color: #fff;
line-height: 200px;
}
同じカテゴリの記事一覧へ