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

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

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

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

CSS

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

Q&A

解決済

2回答

931閲覧

HTML:テーブル内セルの垂直方向の中央揃えができません

TAK-AC

総合スコア1

HTML

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

CSS

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

0グッド

0クリップ

投稿2021/02/10 04:21

セル内の垂直方向の中央揃えがうまくいきません

htmlで表形式を使い、価格表を作っています
table.plan_boxで作った表を、blockで縦並びに表示しようと考えました。
二段目の『タイトル』、三段目『説明』について垂直方向の中央揃えを行おうと思い、vertical-alignを設定しましたがうまくいきません
四段目は上揃えのままにしたいです。
よろしくお願いいたします。

該当のソースコード

html

1<table class="plan_box" border="3" frame="box"> 2 <tr> 3 <th> 4 画像が入ります 5   </th> 6   <td class="pb1"> 7 <h3>タイトル</h3> 8   </td> 9 <td class="pb2"> 10    <p>説明</p>   11   </td> 12 <td class="pb3"><p>価格</p> 13 <p class=pb3>180,000円</p> 14 </tr> 15</table>

css

1table.plan_box { 2 width: 24%; 3 display: table; 4 height: 100%; 5} 6 7table.plan_box th, 8table.plan_box td{ 9 display: block; 10} 11 12table.plan_box th{ 13 height: 280px; 14} 15 16td.pb1{ 17 height: 80px; 18 vertical-align: middle; 19} 20.pb2{ 21 height: 180px; 22 vertical-align: middle; 23} 24.pb3{ 25 height: 180px; 26 vertical-align: top; 27}

試したこと

css中 td.pb1にvertical-align: middle;を設定しました。
.pb1には詳細度を考え『td.pb1』として設定しました

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

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

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

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

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

yambejp

2021/02/10 05:16

不要に見える半角・全角のスペースが大量にあるようです これは削除してよいのでしょうか?
guest

回答2

0

テーブルセルをdisplay:blockにしてはだめでしょう・・
もはや表の体をなしていません
それでもどうしてもというならdisplay:flexにして
align-items: centerを指定するとかで多少は調整できます

投稿2021/02/10 04:38

yambejp

総合スコア115010

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

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

TAK-AC

2021/02/10 04:51

ありがとうございました。
guest

0

ベストアンサー

vertical-alignは、位置を揃えたい「インライン要素」か「テーブルセル」に使うため、thやtdに対してdisplay: block;してしまっているので効かないと思います。

縦並びにしたいのでしたら
現在trで全てのテーブルセルを囲っていますが
それを、テーブルセルそれぞれ囲むように変更するか、(参考になると思います→ https://tabletag.net/ja/)
既に回答があるように、display:flex;にして、文字揃えもflexboxとして変更していくかになると思います。

あと、<p class=pb3>180,000円</p>後のtdの閉じタグが抜けています。

投稿2021/02/10 04:54

pondering

総合スコア104

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問