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

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

ただいまの
回答率

90.33%

  • JavaScript

    17532questions

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

  • jQuery

    7110questions

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

  • HTML5

    4300questions

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

  • CSS3

    2211questions

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

クロスフェードのスライダーパネルを複数設置

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 642

owl

score 33

前提・実現したいこと

進む、戻るボタンで画像がフェードイン、フェードアウトするスライダーを実現したいのですが、このスライダーを一つ設置した場合は上手くいきました。しかし二つ設置した場合、同じクラス名を使っているため連動してしまっています。これを個別で動かしたいです。

試したこと

前回質問したスライドショーを複数設置を参考にしてthisを使って階層を辿ってslideを取得しようとしてみたのですが、書き方が間違っているためか上手く行きませんでした。
ご回答よろしくお願いします。

該当のソースコード

https://jsfiddle.net/8z00nysd/2/

$(function(){

    var img = $('.slide').children('img');
    var num = img.length;
    var count = 0;
    img.eq(0).addClass('show');

    $('.slide__next').click(function(){
        img.eq(count).removeClass('show');

        if(count>=num-1) {
            count = 0;
        } else {
            count ++;
        }

        img.eq(count).addClass('show');
    });

    $('.slide__prev').click(function(){
        img.eq(count).removeClass('show');

        if(count<=0) {
            count = num-1;
        } else {
            count --;
        }

        img.eq(count).addClass('show');
    });

});
    <div class="wrapper">

        <div class="slideWrapper">
            <ul class="slide">
                <img src="https://placehold.jp/f44242/f44242/150x150.png">
                <img src="https://placehold.jp/f4d041/f4d041/150x150.png">
                <img src="https://placehold.jp/23e05c/23e05c/150x150.png">
                <img src="https://placehold.jp/2fd2ef/2fd2ef/150x150.png">
            </ul>
            <p class="slide__prev">
                戻る
            </p>
            <p class="slide__next">
                進む
            </p>
        </div>

        <div class="slideWrapper">
            <ul class="slide">
                <img src="https://placehold.jp/f44242/f44242/150x150.png">
                <img src="https://placehold.jp/f4d041/f4d041/150x150.png">
                <img src="https://placehold.jp/23e05c/23e05c/150x150.png">
                <img src="https://placehold.jp/2fd2ef/2fd2ef/150x150.png">
            </ul>
            <p class="slide__prev">
                戻る
            </p>
            <p class="slide__next">
                進む
            </p>
        </div>

    </div>
*{
    margin: 0;
    padding: 0;
}

img{
    vertical-align: bottom;
}

ul{
    list-style: none;
}

.wrapper{
    width: 300px;
}

.slideWrapper{
    width: 150px;
    float: left;
}

.slide{
    min-height: 150px;
    position: relative;
}

.slide img{
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: 0;
    transition: 0.7s;
}

.slide .show{
    opacity: 1;
    z-index: 1;
}

.slide__prev,
.slide__next{
    cursor: pointer;
    padding: 10px;
    font-size: 12px;
}

.slide__prev{
    float: left;
    margin-left: 5px;
}

.slide__next{
    float: right;
    margin-right: 5px;
}

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

jQueryはjquery-2.2.4.minです。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

var img = $('.slide').children('img'); を共用しているから当然どちらのボタンを押しても動きます。

$( '.slideWrapper' ).each( function(){
    /* スライドセット毎の処理 */
} );

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/01 14:28

    ご回答ありがとうございます。
    この様に記述するということでしょうか。

    $( '.slideWrapper' ).each( function(){
    var img = $('.slide').children('img');
    var num = img.length;
    var count = 0;
    img.eq(0).addClass('show');
    } );

    キャンセル

  • 2017/03/01 14:29

    動きましたか?

    キャンセル

  • 2017/03/01 14:38

    記述しましたが、進む戻るボタンを押しても無反応です。
    試しに$('.slide__next').clickと$('.slide__prev').clickをそれぞれeachで囲むようにしても変わらずでした。

    お答え頂いたのに申し訳ありません。

    キャンセル

  • 2017/03/01 14:49

    「スライドセット毎の処理」にはボタンクリックも含まれるので、それも含めて書くようにしてみては?

    > $('.slide__next').clickと$('.slide__prev').clickをそれぞれeachで囲むようにしても
    それぞれ囲んでどうなると思ったのでしょうか。 $( '.slideWrapper' ).each(function(){}); はクラスにslideWrapper を持つ要素に順にfunction(){}を実行するものです。

    【jQueryのeach()で複数の要素、配列、オブジェクトをループ処理】
    http://www.flatflag.nir87.com/each-1325

    キャンセル

  • 2017/03/01 14:59

    eachで変数のセットからボタンクリックの処理まで囲んでみたのですが、
    変化はありませんでした。

    下記に記述したコードアップしました。
    https://jsfiddle.net/efofz6Ly/1/

    キャンセル

  • 2017/03/01 15:03

    https://jsfiddle.net/efofz6Ly/3/
    でも
    https://jsfiddle.net/efofz6Ly/2/
    でも。

    キャンセル

  • 2017/03/01 15:19

    ご回答ありがとうございます。
    まさに自分が実装したいことです。
    カンマ区切りでthisを使うか、変数にthisを代入してfindを使えば良いのですね。
    勉強になりました。本当にありがとうございます。

    キャンセル

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

  • ただいまの回答率 90.33%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • JavaScript

    17532questions

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

  • jQuery

    7110questions

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

  • HTML5

    4300questions

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

  • CSS3

    2211questions

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