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

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

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

FlexはFlash PlayerやAdobe Airで動作するRIA(リッチインターネットアプリケーション)を開発する為のフレームワークです

URL

URL(ユニフォームリソースロケータ)とは、インターネット上のリソース(Webページや電子メールの宛先等)を特定するための形式的な記号の並びの事を言う。

CSS

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

Q&A

解決済

2回答

1240閲覧

flex横並びで高さを揃える方法

berrys

総合スコア5

Flex

FlexはFlash PlayerやAdobe Airで動作するRIA(リッチインターネットアプリケーション)を開発する為のフレームワークです

URL

URL(ユニフォームリソースロケータ)とは、インターネット上のリソース(Webページや電子メールの宛先等)を特定するための形式的な記号の並びの事を言う。

CSS

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

0グッド

0クリップ

投稿2019/12/27 01:25

編集2019/12/27 02:16

ホームページを自分で作っています。
初心者です。

flexでコンテンツを横並びにしたのですが高さが揃いません。
いろいろと自分なりに調べて試したのですがうまくいきません。

高さを揃える方法を教えてください。
よろしくお願いします。

【URL】
http://berryslife.com/onlinestore/seedling.shtml

【HTML】

<p style="font-size:medium;padding-top : 50px;margin-left : 15px;">名札ラベル・接木テープ</p> <div class="notice4" style="margin-top : 20px;"><a href="http://berryslife.com/onlinestore/seedling/sasiraberu.shtml"> <div class="notice-item4" style="border: 1px solid #edb195;border-radius: 5px;margin : 5px;padding: 10px;width: 230px;"> <img src="http://berryslife.com/officialsite/store/seedling/sasiraberu1.png" width="208" height="208"> <h4 style="font-size : 90%;line-height : 1.2;padding-left : 30px;">挿しラベル</h4> </div> </a><a href="http://berryslife.com/onlinestore/seedling/newmedel.shtml"> <div class="notice-item4" style="border: 1px solid #edb195;border-radius: 5px;margin : 5px;padding: 10px;width: 230px;"> <img src="http://berryslife.com/officialsite/store/seedling/newmedel.png" width="208" height="208"> <h4 style="font-size : 90%;line-height : 1.2;padding-left : 30px;">ニューメデール 25mm<br> 【ミシン目なし】</h4> </div> </a></div>

【CSS】
.notice4 {
display: flex;
flex-wrap: wrap;
}

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

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

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

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

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

H40831

2019/12/27 01:34

高さを揃えるというのは、全て同じサイズにしたいという意味ですか? それとも、上下の中間にポジショニングしたいという意味ですか?
berrys

2019/12/27 01:38

要素の高さを一番高い要素に広げたいのです。 【名札ラベル・接木テープ】でいうと 挿しラベルの要素の高さをニューメデールの高さに揃えたいのです。
H40831

2019/12/27 02:00

コードを書くときは、編集画面にあるcode機能を使うと読みやすくなりますよ。 回答に追記しました。
guest

回答2

0

flexnotice4の子要素の高さは揃っています。
問題なのはflexの子要素がaの時、その子要素であるdiv(class="notice4-item")の高さが揃っていないことです。
方法は色々あるのですが、一番わかり易いのは対象のaに対しても
display:flexを付与することです。

投稿2019/12/27 01:46

編集2019/12/27 01:47
macaron_xxx

総合スコア3191

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

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

berrys

2019/12/27 02:08

ありがとうございます。 子要素に .notice-item4 { display:flex; } と指定すると子要素の画像と文字が横並びになってレイアウトが崩れます。 code機能の使い方が良く分からなくて すいません。
macaron_xxx

2019/12/27 03:47

つけるところが違います。 .notice-item4は孫要素になっているものです。 aに対してflexを指定します。
berrys

2019/12/27 07:21

下記の場合は height:100% を外すと外枠線が揃わなくなりました。 macaron_xxx さんがおっしゃっていた ↑ の 意味がわかりました。 aにflexを指定したら綺麗に揃いました。 すいませんでした。 どうもありがとうございました。
guest

0

ベストアンサー

Flexboxのチートシート
こちらにできること書いてますご覧ください。

追記
とりあえず下記で縦サイズ揃いました。

css

1.notice-item4{ 2 display: flex; 3 flex-direction: column; 4} 5.notice-tem4 img{ 6 height: 100%; 7}

画像の横サイズを変えたくない場合は、
img.notice-tem4heightを消してflex-grow: 1;に書き換えてみてください。

追記
質問文が編集されて、HTMLの構造が違う話になってきたので要点だけ伝えますと、

  1. display: flex; を指定すると 子要素の縦サイズは自動的に大きいものに合わせるモードになってます。
  2. display: flex; を指定した要素の中身は display: flex; ではありません。(=縦サイズを自動的に合わせてくれません。)
  3. 全ての中身の要素を、きちんと縦サイズをあわせてくれるように display: flex; を指定したうえで、

画像に height: 100%; を書けば、ちゃんと合うとおもいます。
4. display: flex;にすると自動的に、中身をすべて横並びにしてしまうので、縦に並べたい部分には flex-direction: column; を書いてください。

投稿2019/12/27 01:35

編集2019/12/27 02:34
H40831

総合スコア973

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

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

berrys

2019/12/27 02:04

ありがとうございます。 チートシートにある align-self … (子要素の垂直方向の揃え) の align-self: stretch; を追加してみましたが揃いません。 試しに子要素に .notice-item4 { align-self: stretch; } と指定しましたが揃いません。
berrys

2019/12/27 02:19

.notice-item4{ display: flex; flex-direction: column; } img.notice-tem4{ height: 100%; } でやってみましたが揃いません。 HTMLに追記しました。 コンテンツの茶色の枠の高さが揃わないのです。
H40831

2019/12/27 02:25 編集

ごめんなさい、imgのセレクタ、全体的に間違えてました。 正しくは .notice-item4 img{ ... } です
H40831

2019/12/27 02:35

HTMLの構造が変わったので、回答に追記をしました。
berrys

2019/12/27 03:01

ありがとうございます。 .notice4 { display: flex; flex-wrap: wrap; align-self: stretch; } .notice-item4 { display: flex; flex-direction: column; height: 100%; } これでうまくいきました。 お手数をおかけしました。 どうもありがとうございました。
macaron_xxx

2019/12/27 03:48

height:100%など不要なものが含まれていますが…。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問