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

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

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

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

jQuery

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

HTML

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

Q&A

解決済

1回答

919閲覧

【jQuely】index()メソッドを利用して、クリックした要素とスライドショーを連動させる方法

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

jQuery

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

HTML

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

0グッド

0クリップ

投稿2021/10/22 06:06

編集2021/10/22 06:07

実装したいもの
.FlowItemというクラスをクリックしたら、.swiper-slide正しい順番で表示されるようにしたい。

・初期状態は1番目のブロックがクリックされた状態で、スライドショーはslide1が表示されている

2番目のブロックをクリックしたら、スライドショーはslide2を表示する

3番目のブロックをクリックしたら、スライドショーは3を表示する

要は、ブロックの順番と、表示されるスライドショーの順番を合わせたいということです。

現在の挙動
クリックしたら、スライドをするという動きは実装できています。
スライドショーが一つずれてしまっているイメージです。
JavaScriptは配列で取る時に、0から数えるというのは知っていますが、indexに-1をしてもダメだったので、記述ミスかと思いますが、書き方がわかりません。
console.logの結果としては、1番目のブロックをクリックすると'0'が取れます。あとはそれに+1されていくイメージです。

具体的な挙動
2番目のブロックをクリックする→反応しない、というより1番目のスライドが表示される
3番目のブロックをクリックする→2番目のスライドが表示される

わかりにくければすみませんが、知恵をお貸しいただければと思います。

jQuely

$('.FlowItem').on('click', function(){ const index = $(this).index();//クリックした要素のインデックスを取得 console.log(index); swiper.slideTo(index);//指定のスライドを呼び出し }); コード

HTML

<section class="secFlow"> <div class="commonInner"> <div> <div class="commonTitleBlock"> <h2 class="secCommonTitle">見出し</h2> <p class="secCommonEnTitle">Flow</p> </div> <div class="FlowList"> <p>テキスト。</p> <ul> <li class="FlowItem"> <span>1</span> <p>1番目のブロック</p> </li> <li class="FlowItem"> <span>2</span> <p>2番目のブロック</p> </li> <li class="FlowItem"> <span>3</span> <p>3番目のブロック</p> </li> <li class="FlowItem"> <span>4</span> <p>4番目のブロック</p> </li> <li class="FlowItem"> <span>5</span> <p>5番目のブロック</p> </li> </ul> </div> </div> <div class='swiper-wrap'> <!-- Slider main container --> <div class="swiper"> <!-- Additional required wrapper --> <div class="swiper-wrapper"> <div class="swiper-slide">slide 1</div> <div class="swiper-slide">Slide 2</div> <div class="swiper-slide">Slide 3</div> <div class="swiper-slide">Slide 4</div> <div class="swiper-slide">Slide 5</div> </div> </div> <div class="swiper-button-prev"></div> <div class="swiper-button-next"></div> </div> </div> </section> コード

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

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

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

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

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

guest

回答1

0

ベストアンサー

FlowItemクラスのついた要素のウチ自分が何番目の要素か確認するなら

$('.FlowItem').index(this)

です。これをターゲットとなる要素にeq()などで指定します

投稿2021/10/22 06:59

yambejp

総合スコア116734

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問