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

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

詳細はこちら
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

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

Q&A

解決済

3回答

3319閲覧

テーブル隠し行を開閉したい

Sibutakiti

総合スコア18

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

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

0グッド

0クリップ

投稿2019/10/21 15:06

テーブルの一部の行を初期値では隠し行として
文字をクリックしたら隠し行が表示されるように考えているのですが
うまくいきません。
イメージでは下記の通りです。
初期画面
イメージ説明

このうち所有機器をクリックしたら下記の通り
イメージ説明
となる仕様で作成しているのですが、うまくいきません。
(所有者をクリックしても同じような動作で内容を表示させたい)
一応作っているコードは下記の通り。
テーブルがなければ動作するのですが、
テーブルをいれるととたんにうまくいかなくなりました。
ご教授方よろしくお願い致します。

html

1<head> 2 <script src="http://code.jquery.com/jquery-1.11.1.js"></script> 3</head> 4 <table border="1"> 5 <tr> 6<section id="acdemo1"> 7 <ul> 8<p> 9<td>所有機器</td> 10</p> 11</tr> 12<tr> 13 <td>1</td> 14 <td>iPhone</td> 15 </tr> 16 <tr> 17 <td>2</td> 18 <td>iPad</td> 19 </tr> 20<tr> 21 <td>3</td> 22 <td>iPod</td> 23 </tr> 24 <tr> 25 <td>4</td> 26 <td>Mac Book Pro</td> 27 </tr> 28</ul> 29</section> 30</ul> 31<tr> 32<section id="acdemo1"> 33<ul> 34<p> 35<td>所有車</td> 36</p> 37</tr> 38<tr> 39 <td>1</td> 40 <td>コロナ</td> 41 </tr> 42<tr> 43 <td>2</td> 44 <td>ミラ</td> 45</tr> 46</table> 47</ul> 48</section> 49<style> 50 51</style> 52<script> 53$(function() { 54 55 //.accordion1の中のp要素がクリックされたら 56$('.accordion1 p').click(function() { 57//クリックされた.accordion1の中のp要素に隣接するul要素が開いたり閉じたりする。 58$(this).next('ul').slideToggle(); 59 }); 60 }); 61</script> 62 63

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

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

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

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

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

guest

回答3

0

trタグの直下にsectionタグを置いてはいけません
列数の構成が違うtrをおくときれいに表示することはできません。
以前もお伝えしたかもしれませんが正しいHTMLを書くところから
始めてください

sample

テーブルを整え、カスタムデータを使って適当にグルーピングしました

javascript

1<script> 2$(function(){ 3 $('tr[data-position=body]').hide(); 4 $('tr[data-position=head]').on('click',function(){ 5 $('tr[data-kind='+$(this).data('kind')+']').not($(this)).toggle(); 6 }); 7}); 8</script> 9<table border="1"> 10<tbody> 11<tr data-kind="machine" data-position="head"> 12<td colspan="2">所有機器</td> 13</tr> 14<tr data-kind="machine" data-position="body"> 15<td>1</td> 16<td>iPhone</td> 17</tr> 18<tr data-kind="machine" data-position="body"> 19<td>2</td> 20<td>iPad</td> 21</tr> 22<tr data-kind="machine" data-position="body"> 23<td>3</td> 24<td>iPod</td> 25</tr> 26<tr data-kind="machine" data-position="body"> 27<td>4</td> 28<td>Mac Book Pro</td> 29</tr> 30<tr data-kind="car" data-position="head"> 31<td colspan="2">所有車</td> 32<tr data-kind="car" data-position="body"> 33<td>1</td> 34<td>コロナ</td> 35</tr> 36<tr data-kind="car" data-position="body"> 37<td>2</td> 38<td>ミラ</td> 39</tr> 40</tbody> 41</table>

投稿2019/10/23 00:32

編集2019/10/23 01:43
yambejp

総合スコア116688

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

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

Sibutakiti

2019/10/23 01:11

もう少し勉強してから再投稿します。ありがとうございました
yambejp

2019/10/23 01:43

一応現時点で提示されている情報をもとにsampleつけときました
Sibutakiti

2019/10/23 01:54

ありがとうございました。欲しかったのはまさにご回答頂いたものです。ほんと勉強して書けるよう努力します。
guest

0

自己解決

質問に不備あり。一旦、終了と致します。

投稿2019/10/23 01:21

Sibutakiti

総合スコア18

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

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

0

そもそもテーブルの組み方が間違っています。

Jqueryも#と.の違いを調べてみてください

投稿2019/10/21 17:57

AMK

総合スコア765

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問