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

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

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

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

Q&A

解決済

2回答

256閲覧

addClassを使ってjQueryのアコーディオンを動かしたいです

hayachi6446

総合スコア5

jQuery

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

0グッド

0クリップ

投稿2020/02/19 14:20

前提・実現したいこと

jQueryを使ってアコーディオンを作りたいのですが、思い通りに動きません。
どう訂正すれば良いか教えていただけるとありがたいです。

該当のソースコード

html

1 <div class="questions"> 2 <h2 class="txtl">よくある質問</h2> 3 <section class="questionslist"> 4 <div class="panel-group"> 5 <div class="panel panel-default"> 6 <div class="questionsheading"> 7 <h4 class="panel-title"> 8 <a href="#collapseFirst" class="txtm"> 9 プログラミングスキルは必要ですか? 10 </a> 11 </h4> 12 </div> 13 <div id="collapseFirst" class="collapse" style="height: 0px;"> 14 <div class="questionsbody" > 15 <p class="txts"> 16 いいえ、必要ありません。しかし、iSaraでは参加費以上の金額が稼げることを保障しています。 従って、事前通話面談時点で簡単なテストを実施し、場合によってはお断りをしております。この点だけはご了承ください。 17 </p> 18 </div> 19 </div> 20 </div> 21 </div> 22 </section> 23 </div>

css

1.questions { 2 padding: 40px 10%; 3 text-align: center; 4} 5 6.questions .txtl { 7 margin-bottom: 40px; 8} 9 10.questionslist { 11 width: 1170px; 12 max-width: calc(100% - 40px); 13 margin: 0 auto; 14 text-align: left; 15} 16 17.panel-group { 18 margin-bottom: 20px; 19} 20 21.panel-group .panel { 22 margin-bottom: 0; 23 border-radius: 4px; 24} 25.panel-default { 26 border: none; 27} 28 29.questionsheading { 30 padding: 20px 20px; 31 background-color: #fff !important; 32 color: #000000 !important; 33 border: 1px solid #e5e5e5 !important; 34} 35 36.panel-title { 37 margin-top: 0; 38 margin-bottom: 0; 39 font-size: 16px; 40 color: inherit; 41} 42 43.questionsheading h4 a { 44 cursor: pointer; 45 display: block; 46} 47.panel-title>.small, .panel-title>.small>a, .panel-title>a, .panel-title>small, .panel-title>small>a { 48 color: inherit; 49} 50 51.questionsbody { 52 border: none !important; 53 background-color: #fff; 54 padding: 20px; 55} 56

jQuery

1$(function () { 2 3 $('.questions .txtm').click(function() { 4 var $questionsbody = $('.collapse').find('.txts'); 5 if($questionsbody.hasClass('open')) { 6 $questionsbody.removeClass('open'); 7 $questionsbody.slideUp(); 8 9 } else { 10 $questionsbody.addClass('open'); 11 $questionsbody.slideDown(); 12 } 13 }); 14});

補足情報(FW/ツールのバージョンなど)

これはiSARAのというサイトの模写です。

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

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

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

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

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

kei344

2020/02/19 14:25

「思い通りに動きません」とは「何をしたときに」「どうなると思って」「どうなったのか」を、出ているエラーなどと併せて、具体的に記述されたほうが回答を得られやすいと思います。
hayachi6446

2020/02/19 14:42 編集

説明不足でした。 アドバイスありがとうございます! htmlに書いてある「プログラミングは必要ですか?」をクリックしたら、その下に「いいえ、必要ありません」の文章が表示されるようにしたいです。 しかし、クリックしても下に文章が表示されません。 クリックする前はbootstrapのcollapseクラスで「いいえ、必要ありません」は隠れています。 エラーはとくに見当たらなかったです。
guest

回答2

0

ベストアンサー

style 属性を外してください。

HTML

1 <!--div id="collapseFirst" class="collapse" style="height: 0px;"--> 2 <div id="collapseFirst" class="collapse">

しかし、Bootstrap の Collapse を使っているのであれば Bootstrap ですべきでしょう。
https://getbootstrap.com/docs/4.4/components/collapse/

HTML

1<a href="#collapseFirst" class="txtm" data-toggle="collapse">

あるいは

jQuery

1 $('.collapse').collapse('toggle');

投稿2020/02/20 05:40

x_x

総合スコア13749

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

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

hayachi6446

2020/02/20 10:24

ご回答ありがとうございます! style属性を外した結果出来ました。
guest

0

HTMLのstyle="height: 0px;"を外し、jQueryの記述を下記のように変更したらできました。

jQuery

1$(function () { 2 3 $('.questionsheading').each(function(){ 4 $(this).click(function() { 5 $(this).next().slideToggle() 6 return false; 7 }); 8 }); 9 10});

ご協力ありがとうございました!

投稿2020/02/20 10:37

hayachi6446

総合スコア5

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問