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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

HTML

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

CSS

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

Q&A

解決済

2回答

4120閲覧

rowspanによるセル結合について

i-nr

総合スコア15

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

HTML

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

CSS

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

0グッド

0クリップ

投稿2020/08/19 10:25

htmlで下記のような横長のカレンダーを作成をしています。Excelでのイメージ図

黄色部分を固定し、緑部分を横スクロールするイメージです。

黄色部分について、
2行+1行の形にしたいのですが、rowspanやcolspanを使ってみてもうまく行かず、下記のようになってしまいます。
現在のコードでの表示

黄色部分と緑部分を別テーブルにしていることが原因なのでしょうか??
それともスタイル指定の問題でしょうか??
ご教授いただければ幸いです。
よろしくお願いいたします。

下記、現在のソースです。

HTML

1<div class="calendar-box"> 2 <div id="x_data_area"> 3 <!-- 固定したい部分 --> 4 <table id="header" class="csTbl_left"> 5 <tbody> 6 <tr> 7 <td rowspan="2" colspan="1">2020年7月</td> 8 </tr> 9 <tr></tr> 10 <tr><td>印</td></tr> 11 </tbody> 12 </table> 13 14 <!-- スクロールしたい部分 --> 15 <div id="data"> 16 <table class="csTbl"> 17 <tbody> 18 <tr> 19 <th>水</th> 20 <th>木</th> 21 <th>金</th> 22 ... 23 </tr> 24 <tr> 25 <th>1</th> 26 <th>2</th> 27 <th>3</th> 28 ... 29 </tr> 30 <tr class="item"> 31 <td></td> <!--1--> 32 <td>◯</td> <!--2--> 33 <td></td> <!--3--> 34 ... 35 </tr> 36 </tbody> 37 </table> 38 </div> 39 </div> 40</div>

CSS

1.calendar-box { 2 width:100%; 3 background:#fff; 4 overflow:hidden; 5 display:block; 6 margin-bottom:10px; 7} 8 9.csTbl { 10 border-collapse:collapse; 11 font-size: 13px; 12 width: 100%; 13 table-layout: fixed 14} 15.csTbl td, .csTbl th { 16 padding:6px; 17 text-align: center; 18 width: 20px; 19 border-right: 0.5px solid #fff; 20} 21.csTbl th { 22 background:#f2f2f2; 23} 24 25.csTbl_left { 26 background:#f2f2f2; 27 border-collapse:collapse; 28 font-size: 13px; 29 width: 100%; 30 table-layout: fixed 31} 32.csTbl_left td { 33 padding:6px; 34 text-align: center; 35 width: 20px; 36} 37 38.item td { 39 border-right: 0.5px solid #eee 40} 41 42#x_data_area { 43 position:relative; 44} 45 46#header { 47 width: 13%; 48 position: absolute; 49} 50 51#data { 52 width:87%; 53 position: relative; 54 left:13%; 55 top:0; 56 overflow-x:scroll; 57}

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

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

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

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

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

guest

回答2

0

単純にセルのheightで調整すればいいのでは。

html

1 <table id="header" class="csTbl_left"> 2 <tbody> 3 <tr> 4 <th>2020年7月</th> 5 </tr> 6 <tr><td></td></tr> 7 </tbody> 8 </table> 9

css

1#header th { 2 height: 46px; 3 padding: 6px; 4}

他に一つのテーブルにして下記の方法もあります。

CSSのposition: stickyでテーブルのヘッダー行・列を固定する - Qiita

投稿2020/08/19 20:50

hatena19

総合スコア33782

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

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

i-nr

2020/08/20 01:32

ありがとうございます。 確かにheightで調整すればいいですね。。 「position: sticky」を使ったものも作ってみます! ご回答いただきありがとうございました!
guest

0

ベストアンサー

黄色部分と緑部分を別テーブルにしていることが原因なのでしょうか??

そうですね、左側のテーブルにはrowspanを使った行しかないので、高さが余計に取られることはありません。

(テーブルを分けずに、position: stickyを使ってヘッダ固定させるような手段も考えられます)

投稿2020/08/19 10:34

maisumakun

総合スコア145208

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

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

i-nr

2020/08/20 01:31

ありがとうございます。 rowspanを使った行しかないと高さが取れないのですね。勉強になりました! 「position: sticky」使ったことがなかったので知りませんでした。 作り直してみます! ご回答いただきありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問