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

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

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

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

jQuery

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

Q&A

解決済

1回答

1069閲覧

JQuery の画像スライドショウでグループ化したい

hidepon

総合スコア206

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2017/08/22 05:31

編集2017/08/22 05:54

「Magnific Popup」というスライドショウプラグインを利用しようとしています。
http://dimsemenov.com/plugins/magnific-popup/documentation.html
を参考にして設定をしようとしています。
例えば
ブログみたいな感じで数ブロックにわたって個別のスライドショウを複数設定する場合に

<div class="parent-container"> <a href="path-to-image-1.jpg">Open popup 1</a> <a href="path-to-image-2.jpg">Open popup 2</a> <a href="path-to-image-3.jpg">Open popup 3</a> </div> $('.parent-container').magnificPopup({ delegate: 'a', type: 'image', gallery: { enabled:true } });

とすれば良いと考えました。
しかし

<div class="block"> <div class="parent-container"> <a href="path-to-image-1.jpg">Open popup 1</a> <a href="path-to-image-2.jpg">Open popup 2</a> <a href="path-to-image-3.jpg">Open popup 3</a> </div> </div> <div class="block"> <div class="parent-container"> <a href="path-to-image-4.jpg">Open popup 1</a> <a href="path-to-image-5.jpg">Open popup 2</a> <a href="path-to-image-6.jpg">Open popup 3</a> </div> </div><div class="block"> <div class="parent-container"> <a href="path-to-image-7.jpg">Open popup 1</a> <a href="path-to-image-8.jpg">Open popup 2</a> <a href="path-to-image-9.jpg">Open popup 3</a> </div> </div>

としたとき。
全ての画像がまとまって取り込まれて
1つのギャラリーとして表示されてしまいます。
:eqとかを利用して個別のブロックを識別しながら
表示できればと考えていますが、うまくいきません。
宜しくお願いいたします。

(追記)
例えば、ブロック(領域)が5つあるとします。各々の領域に複数の画像ギャラリー用の写真が設定されています。
ブロックAに3枚 →3枚のギャラリー作成
ブロックBに4枚 →4枚のギャラリー作成、
ブロックCに5枚 →5枚のギャラリー作成、
ブロックDに4枚 →4枚のギャラリー作成、
ブロックEに7枚 →7枚のギャラリー作成、
のように5種類のスライドショウを設定するというのが、目標になります。

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

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

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

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

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

m.ts10806

2017/08/22 05:38

私の理解不足かもしれませんが、質問内容のみではどう動けばゴールになるのかがちょっと見えませんでした。その辺りを追記いただけますか?
hidepon

2017/08/22 05:43

すみません。記述中に誤って中途半端に投稿されてしまいました。例えば、ブロック(領域)が5つあるとします。各々の領域に複数の画像ギャラリー用の写真が設定されています。ブロックAに3枚、ブロックBに4枚、ブロックCに5枚、ブロックDに4枚、ブロックEに7枚とします。5種類のスライドショウを設定するというのが、ゴールになります。説明がうまくいっているか不安ですが・・・よろしくお願いいたします
m.ts10806

2017/08/22 05:46

なるほど、なんとなく分かりました。ただ、こちらでは埋もれてしまう可能性があるので質問本文に追記願います。
hidepon

2017/08/22 05:49

有難うございます。追記の件、了解です。いろいろ試行錯誤しているんですが・・・よろしくお願いいたします。
guest

回答1

0

ベストアンサー

結果は同じですが下記のような方法で実現可能と思います。
(ひとまず思いつくもの2パターン)

Classをそれぞれに振る

Class名を1スライド1つにしてそれぞれに直で指定します。

HTML

1<div class="block"> 2 <div class="parent-container1"> 3 <a href="path-to-image-1.jpg">Open popup 1</a> 4 <a href="path-to-image-2.jpg">Open popup 2</a> 5 <a href="path-to-image-3.jpg">Open popup 3</a> 6 </div> 7</div> 8<div class="block"> 9 <div class="parent-container2"> 10 <a href="path-to-image-4.jpg">Open popup 1</a> 11 <a href="path-to-image-5.jpg">Open popup 2</a> 12 <a href="path-to-image-6.jpg">Open popup 3</a> 13 </div> 14</div><div class="block"> 15 <div class="parent-container3"> 16 <a href="path-to-image-7.jpg">Open popup 1</a> 17 <a href="path-to-image-8.jpg">Open popup 2</a> 18 <a href="path-to-image-9.jpg">Open popup 3</a> 19 </div> 20</div>

javascript

1$('.parent-container1').magnificPopup({ 2delegate: 'a', 3 type: 'image', 4 gallery: { 5 enabled:true 6 } 7}); 8$('.parent-container2').magnificPopup({ 9delegate: 'a', 10 type: 'image', 11 gallery: { 12 enabled:true 13 } 14}); 15$('.parent-container3').magnificPopup({ 16delegate: 'a', 17 type: 'image', 18 gallery: { 19 enabled:true 20 } 21});

この方法だとIDでも良いかなと思いました。

eachでブロック内のスライドをそれぞれに。

.block -> .parent-container という構成に必ずなっていることが前提
ブロックをループしてそれぞれにmagnificPopupを当てます。

※提示のHTMLと同じです

HTML

1<div class="block"> 2 <div class="parent-container"> 3 <a href="path-to-image-1.jpg">Open popup 1</a> 4 <a href="path-to-image-2.jpg">Open popup 2</a> 5 <a href="path-to-image-3.jpg">Open popup 3</a> 6 </div> 7</div> 8<div class="block"> 9 <div class="parent-container"> 10 <a href="path-to-image-4.jpg">Open popup 1</a> 11 <a href="path-to-image-5.jpg">Open popup 2</a> 12 <a href="path-to-image-6.jpg">Open popup 3</a> 13 </div> 14</div><div class="block"> 15 <div class="parent-container"> 16 <a href="path-to-image-7.jpg">Open popup 1</a> 17 <a href="path-to-image-8.jpg">Open popup 2</a> 18 <a href="path-to-image-9.jpg">Open popup 3</a> 19 </div> 20</div>

javascript

1 $(".block").each(function(){ 2 $(this).children('.parent-container').magnificPopup({ 3 delegate: 'a', 4 type: 'image', 5 gallery: { 6 enabled:true 7 } 8 }) 9 })

投稿2017/08/22 06:27

m.ts10806

総合スコア80850

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

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

hidepon

2017/08/22 08:42

有難うございます。うまくいきました。同じように考えてやってみてはいたんですが、やはりレベルの差を感じます。本当に有難うございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問