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

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

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

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

Q&A

解決済

2回答

158閲覧

jQueryを使った画面スライド表示について

退会済みユーザー

退会済みユーザー

総合スコア0

jQuery

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

0グッド

0クリップ

投稿2018/11/03 17:26

html <div class="slide-wrapper"> <h2 class="slide-title">にんじゃわんこの一年</h2> <div class="change-btn-wrapper"> <div class="change-btn prev-btn">← 前へ</div> <div class="change-btn next-btn">次へ →</div> </div> <ul class="slides"> <li class="slide active"><img src="https://s3-ap-northeast-1.amazonaws.com/progate/shared/images/lesson/jquery/advanced/spring.jpg"></li> <li class="slide"><img src="https://s3-ap-northeast-1.amazonaws.com/progate/shared/images/lesson/jquery/advanced/rainy.jpg"></li> <li class="slide"><img src="https://s3-ap-northeast-1.amazonaws.com/progate/shared/images/lesson/jquery/advanced/autumn.jpg"></li> <li class="slide"><img src="https://s3-ap-northeast-1.amazonaws.com/progate/shared/images/lesson/jquery/advanced/winter.jpg"></li> </ul> <div class="index-btn-wrapper"> <div class="index-btn">1</div> <div class="index-btn">2</div> <div class="index-btn">3</div> <div class="index-btn">4</div> </div> </div> css .slide { display: none; } .active { display: block; } // jQuery $(function() { $('.index-btn').click(function() { $('.active').removeClass('active'); var clickedIndex = $('.index-btn').index($(this)); $('.slide').eq(clickedIndex).addClass('active'); var slideIndex = $('.slide').index($('.active')); $('.change-btn').show(); if (slideIndex == 0) { $('.prev-btn').hide(); } else if (slideIndex == 3) { $('.next-btn').hide(); } }); $('.change-btn').click(function() { var $displaySlide = $('.active'); $displaySlide.removeClass('active'); if ($(this).hasClass('next-btn')) { $displaySlide.next().addClass('active'); } else { $displaySlide.prev().addClass('active'); } var slideIndex = $('.slide').index($('.active')); $('.change-btn').show(); if (slideIndex == 0) { $('.prev-btn').hide(); } else if (slideIndex == 3) { $('.next-btn').hide(); } }); });

1~4の番号ボタンを押したり、「前へ→ ←次へ」ボタンを押して、画面をスライドさせたいのですが、
jQueryコードの7行目。$('.change-btn').show(); ← このコードが何故、必要なのでしょうか?
この7行目がコードがないと、一度言えた「前へ→ ←次へ」ボタンは表示されません。

五行目に$('.slide').eq(clickedIndex).addClass('active');というコードがあって、activeクラスをつけているのに、
どうして7行目のコードがないと、一度消えた「前へ→ ←次へ」ボタンが表示されないのでしょうか?よろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

$('.slide').eq(clickedIndex).addClass('active'); はスライドを表示。
$('.change-btn').show(); はボタンを表示。

別の物を操作しています。

投稿2018/11/03 17:59

kei344

総合スコア69407

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

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

退会済みユーザー

退会済みユーザー

2018/11/03 23:12

はっ!目から鱗です。2日間、悩んでいました・・。ありがとうございます。
guest

0

jQueryコードの7行目。$('.change-btn').show(); ← このコードが何故、必要なのでしょうか?

このコードでchange-btnというクラスがついた要素のdisplay: noneの状態を打ち消しています。

五行目に$('.slide').eq(clickedIndex).addClass('active');というコードがあって、activeクラスをつけているのに、

どうして7行目のコードがないと、一度消えた「前へ→ ←次へ」ボタンが表示されないのでしょうか?

開発者ツールで確認すると見やすいのですが、
hide()show()は要素に直接スタイルをつけるようになっています。
activeクラスも確かにdisplayを変更しているのですが、CSSのスタイルより、要素に直接当てたスタイルの方が優先されるので、
hide()状態でactiveクラスがついただけでは優先度の違いから表示されません。

コードの読み間違いしてました。
kei344様のおっしゃる通り、activeクラスをつけている要素と、hide()``show()をしている要素は別物です。

投稿2018/11/03 17:54

編集2018/11/03 18:05
dice142

総合スコア5158

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

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

退会済みユーザー

退会済みユーザー

2018/11/03 23:11

回答ありがとうございます。コードが長くなると、何がなんだかわからなくなります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問