質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Q&A

解決済

2回答

1957閲覧

要素内にテキストが納まるようにしたい

kazuhito0106

総合スコア8

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

0グッド

0クリップ

投稿2020/02/19 13:49

前提・実現したいこと

要素内にテキストを納めたいです。
header内にロゴ画像とメニュー一覧を示したレイアウトをhtml5とcss3で作っています。

発生している問題・エラーメッセージ

メニュー一覧にfont-sizeが18pxのテキスト(Cute)を書きましたが、
要素内に納まらず、ややpadding-bottom内にCuteが少し入ってしまいます。

イメージ説明

該当のソースコード

html5

1 <header> 2 <div class="wrapper"> 3 <div class="header-left"> 4 <img src="./img/logo.png" alt="ロゴ"> 5 </div> 6 <div class="header-right"> 7 <ul> 8 <li>Cute</li> 9 <li>Cute</li> 10 <li>Cute</li> 11 </ul> 12 </div> 13 </div> 14 <div class="clear"></div> 15 </header>

css3

1header { 2 width: 100%; 3 height: 70px; 4} 5 6.wrapper { 7 width: 980px; 8 margin: 0 auto; 9} 10 11.header-left { 12 padding: 10px 0; 13 float: left; 14 height: 50px; 15} 16 17.header-right { 18 float: right; 19} 20 21.header-right ul { 22 padding: 26px 0; 23 height: 18px; 24} 25 26.header-right li { 27 display: inline-block; 28 list-style: none; 29 margin-left: 40px; 30 font-weight: bold; 31 font-size: 18px; 32 height: 18px; 33} 34 35.clear { 36 clear: both; 37} 38

試したこと

要素内の高さと幅はインライン要素では指定できないため、CSSの.header-right li {}内でインラインブロック要素へ変更しています。
ul要素の親要素がフロートによって浮いていたため、子要素の高さが分からないことが原因?と考え、htmlより空のdivタグを用意し、cssにてclear: both;と
することで、子要素の高さを認識させるようにしました。

補足情報(FW/ツールのバージョンなど)

ブラウザ:Google Chrome
使用言語:html5, CSS3

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

すべてのCSSコードが書かれているかわからない&ブラウザの環境によって変わりますが、 height で指定している高さよりも行ボックスの高さが大きいのが原因だと思います。
line-heightで行ボックスの高さをheightと同じ値にしてあげるとどうでしょうか?

css

1.header-right li { 2 display: inline-block; 3 list-style: none; 4 margin-left: 40px; 5 font-weight: bold; 6 font-size: 18px; 7 height: 18px; 8 line-height: 18px; // 追加しました。 9}

line-height - CSS カスケーディングスタイルシート MDN

投稿2020/02/20 00:29

shgtkshruch

総合スコア665

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kazuhito0106

2020/02/24 10:54

回答ありがとうございます。ご指摘箇所にline-height: 18px;を追加すると要素内にテキストが納まるようになりました。該当箇所のline-height値はnormalであったので、heightの18pxよりも大きかったのが原因と考えます。解決できました!ありがとうございました!
guest

0

なぜそのようになってしまうのか。それは、「文字は少し下にずれる」からです。なのでCSSの構造がおかしいわけではありません。

急いで作成したこちらの画像を見てください。
画像
これは、18pxのテキストと18pxのボックスを並べて拡大したものです。

このように、ずれているのがわかりますよね。

なので、対処法としてはテキストサイズとボックスの高さは同じにせず、テキストサイズを少し小さくするのが簡単だとおもいます。

また、画像のHTMLは下記に記述しておきます。

html

1<!DOCTYPE html> 2<html lang="ja"> 3 <head> 4 <meta charset="utf-8"> 5 <title>サンプル</title> 6 </head> 7 <body> 8 <span style="font-size:18px;">abc123あいう</span><span style="display:inline-block;background:#333333;height:18px;width:50px;"></span> 9 </body> 10</html>

投稿2020/02/19 14:35

編集2020/02/19 14:36
Res

総合スコア184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問