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

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

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

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

Q&A

解決済

2回答

3923閲覧

jQuery openクラス?について

kenj

総合スコア29

jQuery

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

0グッド

3クリップ

投稿2017/08/28 09:16

初めまして。当サイトは初めてですが、初心者です。
質問宜しくお願い致します。

###発生している問題・エラーメッセージ

アコーディオンを作ろうとしていて下記のコードの中で
hasClass('open') ,
removeClass('open')
の部分で悩んでいます。
「open」を付ける・取り外すでスライドの開閉状態がなぜ識別されるのかが分かりません。
もしHTMLやCSSで事前にopenについて記述していればopenを付けたり外したりする事で
開閉の状態が認識ができるのは分かるのですが、htmlやcssで「open」について何も触れていない
のに(記述が無いのに)openの付け外しで開閉がなぜ識別されるのか疑問に思っています。
初歩的で意味の分かりにくい質問で申し訳ございませんが、分かる方いましたら
教えて頂けましたら幸いです。宜しくお願い致します。

###該当のソースコード

$('.faq-list-item').click(function() {
var $answer = $(this).find('.answer');
if($answer.hasClass('open')) {
$answer.removeClass('open');
$answer.slideUp();

$(this).find('span').text('+');

} else {
$answer.addClass('open');
$answer.slideDown();

$(this).find('span').text('-');
}
});
});

###試したこと
自分でopenクラスを付けて試してみたり検索をかけて情報収集試みましたがダメでした。

###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報

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

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

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

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

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

kei344

2017/08/28 11:04

質問文のコードはコードブロックで囲んでいただけませんか? ```(バッククオート3つ)で囲み、前後に改行をいれるか、コードを選択して「<code>」ボタンを押すとコードブロックになります。
guest

回答2

0

ソースコード3行目、hasClass()はその要素に指定したクラスが存在するかどうかを判断します。
この場合だと、要素$answeropenクラスが存在するかどうかを判断しています。

javascript

1if($answer.hasClass('open')) {

HTMLのコードにてopenクラスを記述しない場合、上記if文のelse内が実行されますので、

javascript

1} else { 2$answer.addClass('open');

要素$answerに対してopenクラスが付与されます。
ですのでHTMLにopenクラスを記述しなくても開閉の識別ができます。

投稿2017/08/28 09:46

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

kenj

2017/08/28 11:59

丁寧なご回答ありがとうございました。おかげで理解ができました。助かります。ありがとうございます。
guest

0

ベストアンサー

「該当のソースコード」で$('.faq-list-item')をクリックしたときの動作として、
$answerのopenクラスの有無で非表示にする(slideDown)か表示にする(slideUp)か
の処理を分岐させているから、だと思いますがこれで答えになってますでしょうか…?

投稿2017/08/28 09:41

ranchu

総合スコア51

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

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

kenj

2017/08/28 11:58

丁寧なご回答ありがとうございました。openは開閉の目印のようなものなのですね。 おかげで理解ができました。助かります。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問