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

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

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

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

CSS

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

Q&A

解決済

1回答

812閲覧

セルごとに横幅を変えられるテーブルを作りたいのですが。。。

Hayato1201

総合スコア231

HTML

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

CSS

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

0グッド

0クリップ

投稿2021/05/03 01:59

編集2021/05/03 04:16

下記の様にセルごとに横幅を変えられるテーブルを作成しましたが、これだと例えばcolumn 1の幅を縮めていって2行になった瞬間に他のセルの横幅が変化してしまいます。あるセルの幅を縮めても他のセルの幅が変わらない様にしたいです。その場合どの様な変更を行えば良いでしょうか?ご教授いただけるとありがたいです。。。

html

1<table> 2 <thead> 3 <tr> 4 <th> 5 column 1 6 </th> 7 <th> 8 column 2 9 </th> 10 <th> 11 column 3 12 </th> 13 </tr> 14 </thead> 15 <tbody> 16 <tr> 17 <td> 18 <div class="table-cell"> 19 aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa 20 </div> 21 </td> 22 <td> 23 <div class="table-cell"> 24 aaaa 25 </div> 26 </td> 27 <td> 28 <div class="table-cell"> 29 aaaaaaa 30 </div> 31 </td> 32 </tr> 33 </tbody> 34</table>

css

1thead th { 2 resize: horizontal; 3 overflow: hidden; 4 height: 5vh; 5 background: #CECECE; 6 border: 1px solid #707070; 7} 8 9table { 10 text-align: center; 11 border-collapse:collapse; 12 width: max-content; 13 table-layout:fixed; 14} 15 16.table-cell { 17 overflow: hidden; 18 display: -webkit-box; 19 -webkit-box-orient: vertical; 20 -webkit-line-clamp: 2; 21} 22 23th, 24td { 25 word-break: break-all; 26 border:1px solid #707070; 27 width: max-content; 28 height: 5vh; 29} 30

追記

状況をもう少し説明すると、

最初以下の状態からcolumn 1の幅を縮めていって

状態1

この状態まではテーブル全体の幅が小さくなっていくので他のセルの幅は縮まりません

状態2

しかしここでさらに縮めていき、2行になったあたりでテーブルのサイズが小さくならず変わりにcolumn 3が大きくなっていきます。

状態3

この様にcolumn 1を縮めていって最終的にcolumn 3のサイズが変わらない様にしたいです。

やりたい事は以上なのですが、例えば、以下の様に対応できるかも?と思っています。↓
2行になったところでこの様にcolumn 3のサイズが変わってしまうので下記の様に仮に最初から2行で表示してword-break: break-all;を消せば他のセルの幅が変わってしまうこともなくなります。
しかし下記は無理やり<br>で改行しているのでこれをやめたいです。最初から適当なところで中身の長さに応じて改行される様にできないか?という感じです。。。
イメージ説明

html

1 2 <tbody> 3 <tr> 4 <td> 5 <div class="table-cell"> aaaaaaaaaaaaaaaaaaa 6 <br> 7 aaaaaaaaaaaaaaaaaaaaa 8 </div> 9 </td> 10

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

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

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

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

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

m.ts10806

2021/05/03 02:00

テーブルタグをあきらめるしかないのでは。 列の幅は連動します。
Hayato1201

2021/05/03 02:07

なるほど。。。ちなみにセルの他のセルの幅が変化してしまうのはセルの中身が2行になった瞬間からなのですが、それはなぜでしょうか?最初から2行で表示してword-break: break-all;を指定しなかったらこの事象は起こらない気がするのですが、最初から2行で表示するという様なことは可能でしょうか??
m.ts10806

2021/05/03 03:06

求めてるイメージがわかりません テーブルタグはExcelなどと同じです。
Hayato1201

2021/05/03 04:16

イメージを追記させていただきました。。。
guest

回答1

0

ベストアンサー

css

1th, 2td { 3 word-break: break-all; 4 border:1px solid #707070; 5 width: 1em; 6 height: 5vh; 7} 8th{ 9 width:33vw; 10}

などとするしかないのでは。

投稿2021/05/08 04:00

Lhankor_Mhy

総合スコア36960

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問