🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
HTML

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

CSS

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

Q&A

解決済

2回答

3729閲覧

flexで横並びにしたテキストに下線をつけたい

yukiiiiiiiiiii

総合スコア5

HTML

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

CSS

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

0グッド

0クリップ

投稿2021/03/21 16:12

編集2021/03/21 18:17

下の画像のようなものをcssで表現したいです。
![イメージ説明]

果物のリストと価格のリストをflexで横並びにしています。
しかし、flexで横並びでspace-aroundにしているので、下線を付けようとした時に
下の画像のようになってしまいます。
イメージ説明

こちらが現在のhtml,cssです。
わかりにくい点もあるかと思いますが、ご回答よろしくお願い致します。

html

1<div class="menu_wrap"> 2 <ul class="menu"> 3 <li class="blue_line">りんご</li> 4 <li class="blue_line">ぶどう</li> 5 <li class="blue_line">パイナップル</li> 6 </ul> 7 <ul class="price"> 8 <li class="blue_line">100円</li> 9 <li class="blue_line">120円</li> 10 <li class="blue_line">220円</li> 11 </ul> 12</div>

css

1.menu_wrap { 2 display: flex; 3 justify-content: space-around; 4} 5 6.menu li { 7 border-bottom:1px solid green; 8} 9 10.price li { 11 border-bottom:1px solid green; 12}

解答者様の方法を試したところ、このような形になりました。
フォントサイズは同じなのですがなぜつなぎ目の部分がずれるのでしょうか…
marginなども効かず...
イメージ説明

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

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

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

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

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

takna

2021/03/21 23:44

箇条書きリスト2つを組み合わせて無理やり表にするのは構造的に良ろしくないです。 表組みなので、素直にテーブルタグを使うのが正解です。
guest

回答2

0

ベストアンサー

品名と価格は一対一で対応するものなので、それぞを別のリスト(ul)にするというHTML構造自体が意味的に実体と合致してません。
テーブルにするか、一つのリストにするべきだと思います。そうすれば、HTML構造と実体の意味が合致しますし、CSSもシンプルになります。

html

1<div class="menu_wrap"> 2 <ul class="menu"> 3 <li class="blue_line"> 4 <div class="name">りんご</div> 5 <div class="price">100円</div> 6 </li> 7 <li class="blue_line"> 8 <div class="name">ぶどう</div> 9 <div class="price">120円</div> 10 </li> 11 <li class="blue_line"> 12 <div class="name">パイナップル</div> 13 <div class="price">220円</div> 14 </li> 15 </ul> 16</div>

css

1.menu { 2 max-width: 500px; 3 margin: 0 auto; 4 list-style: none; 5 padding: 0; 6} 7 8.menu li{ 9 display: flex; 10 justify-content: space-between; 11 border-bottom:1px solid green; 12}

投稿2021/03/22 00:20

hatena19

総合スコア34073

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

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

yukiiiiiiiiiii

2021/03/22 08:53

同じulの中に記述したらよかったのですね、ありがとうございます!できました!
guest

0

命題にちょっと無理がありそうです
あえてやるならこんな感じ

CSS

1.menu_wrap { 2display: flex; 3 justify-content:center; 4} 5.menu,.price{ 6 list-style:none; 7 padding:0; 8} 9.menu li { 10 border-bottom:1px solid green; 11 padding-right:150px; 12} 13.price li { 14 border-bottom:1px solid green; 15}

投稿2021/03/21 16:53

yambejp

総合スコア116694

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

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

yukiiiiiiiiiii

2021/03/21 18:18

ご回答ありがとうございます。 試してみたところ、"りんご"の線と"100円"のつなぎ目の線がうまく重ならず、 ”100円"の線が少し上に表示される感じになりました。 font-sizeは同じに設定しているのですが... これはしょうがない現象なのでしょうか... また、無理があるというのはflexを使っているからでしょうか? 重ね重ね申し訳ございません、よろしければご教授お願いいたします。
yambejp

2021/03/22 00:09

構造的に別のものを横方向に連結しているかのように振る舞うのが 無理があると思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問