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

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

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

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

971閲覧

リスト要素全体をリンク指定した時の縦のセンタリングができません。

yukina00235

総合スコア63

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2020/09/01 07:48

すみません、設定しても希望した表示にならずお力をお貸願います。

タイトルのままなのですが、liではなくともdivやspanでもよいのですが、親要素いっぱいを子要素のリンク対象にした場合の子要素の配置がうまくできず困っております。
具体的には以下の感じなのですが…。

CSS

1 li{ 2 width:200px; 3 height:50px; 4 background: plum; 5 margin-bottom: 30px; 6 list-style: none; 7 /*padding-left:20px; ここで指定するとずれるのでNG*/ 8 display: flex; 9 align-items: center; 10 } 11 li a { 12 padding-left:20px; 13 display: block; 14 width:100%; 15 height:100%; 16 background: tomato; 17 } 18 </style>

HTML

1<ul> 2 <li><a href="">テキスト</a></li> 3 <li><a href="">テキスト</a></li> 4 <li><a href="">テキスト</a></li> 5 <li><a href="">テキスト</a></li> 6</ul>

行いたいことは、li内のテキストの縦方向のセンタリングです。
横方向の20pxpはli a に対してのadding-left:20px;指定でできたのですが
縦方向が何か定義するとどこかがずれてしまいます。

display: flex;はdisplay: block;の前の名残りです。
display: block; を付けたら無効になってしまいました。

色々と調べたのですが、子要素全体の定義はあるのですが、センター配置絡みの情報がうまく見つからず…。
すみません、宜しくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

下記でどうですか。

css

1li a { 2/* padding-left:20px;*/ 3 display: block; 4 width:100%; 5 height:100%; 6 background: tomato; 7 text-align: center; /*水平中央揃え*/ 8 line-height: 50px; /*親要素の高さと同じに*/ 9}

文字が増えて折り返しが発生する場合には対応するには、
まずはHTMLでaリンク内のテキストを囲む必要があると思います。

html

1<ul> 2 <li><a href=""><span>テキスト</span></a></li> 3 <li><a href=""><span>テキスト</span></a></li> 4 <li><a href=""><span>テキスト テキスト テキスト</span></a></li> 5 <li><a href=""><span>テキスト テキスト テキスト テキスト<span></a></li> 6</ul>

そうすればCSS Flexboxで簡単に中央寄せできます。

css

1li a { 2 display: block; 3 width:100%; 4 height:100%; 5 background: tomato; 6 text-align: center; /*水平中央揃え*/ 7 display: flex; 8 justify-content: center; 9 align-items: center; 10}

投稿2020/09/01 08:07

編集2020/09/01 11:17
hatena19

総合スコア34075

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

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

yukina00235

2020/09/01 10:27

有難うございます。 line-height:を決めてしまうと、文字が増えた際にボックスの高さが対応できず表示が崩れてしまうのですが、やはりこういった親への全体リンクの設定はサイズなどが決まったものに行うのが一般的なのでしょうか?
hatena19

2020/09/01 11:17

回答に追記しましたので参照ください。
yukina00235

2020/09/01 23:31

有難うございますspanを付けたらflexboxが効くようになりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問