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

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

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

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

受付中

swiperを用いて、モーダルの中にスライダーを作成する

Hiroto_4431
Hiroto_4431

総合スコア7

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0回答

0評価

1クリップ

228閲覧

投稿2022/05/25 08:49

WordPressを組み込んだサイトにおいてSwiperを用いて、モーダルの中にスライダーが入っているというを作っているのですが、

Uncaught TypeError: swiper.slideTo is not a function at HTMLLIElement.<anonymous>

というエラーが出てしまい、どうすればいいのか分かりません。
ちなみに、jsのswiper.slideToという表記をなくせば、モーダルは表示されますが、意図したスライドが出てこないという状況です。何が悪いのでしょうか?
教えてくださると嬉しいです。

PHP

<dl class="p-event_article__row"> <dt class="p-event_article__ttl"><?php the_sub_field('title'); ?></dt> <?php $gallery = get_sub_field('gallery'); if( $gallery ){ ?> <!-- ▼ モーダルコンテンツ ▼ --> <dd class="p-event_article__ctn"> <!-- ▼ コンテンツ ▼ --> <ul class="p-event_article__img"> <?php foreach ( $gallery as $key => $img ) { ?> <li class="js-open-modal modal-cell" data-slide-index="<?php $i++; echo $i; ?>"> <img src="<?php echo $img; ?>" alt="<?php the_title(); ?>"> </li> <?php } ?> </ul> <!-- ▼ モーダル ▼ --> <div class="modal" id="modal"> <div class="modal__overlay js-close-modal"></div> <div class="modal__content"> <button class="modal__close-btn js-close-modal" aria-label="閉じる">×</button> <!-- スライダー --> <div class="swiper modal__slider"> <div class="swiper-wrapper"> <?php foreach ( $gallery as $key => $img ) { ?> <div class="swiper-slide modal__slide"> <img src="<?php echo $img; ?>" alt="<?php the_title(); ?>"> </div> <?php } ?> </div> <div class="swiper-button-prev"></div> <div class="swiper-button-next"></div> </div> </div> </div> </dd> <?php } ?> </dl>

CSS

.modal { position: fixed; top: 0; left: 0; width: 100%; height: 100vh; padding: 30px; display: flex; align-items: center; justify-content: center; transition: opacity 0.3s; pointer-events: none; opacity: 0; z-index: 100; background-color: rgba(120, 123, 131, 0.8); } .modal.is-active { opacity: 1; pointer-events: auto; } .modal__overlay { position: absolute; width: 100%; height: 100%; cursor: pointer; } .modal__content { position: relative; background-color: #fff; width: 100%; max-width: 900px; padding: 20px; } .modal__close-btn { position: absolute; right: 0; top: 0; width: 40px; height: 40px; background: #fff; border: 1px solid #ccc; cursor: pointer; z-index: 10; } .modal-cell { cursor: pointer; } .modal-cell:hover { opacity: 0.6; }

JavaScript

//モーダル修正 window.addEventListener("DOMContentLoaded", () => { // モーダルを取得 const modal = document.getElementById("modal"); // モーダルを表示するボタンを全て取得 const openModalBtns = document.querySelectorAll(".js-open-modal"); // モーダルを閉じるボタンを全て取得 const closeModalBtns = document.querySelectorAll(".js-close-modal"); // Swiperの設定 const swiper = new Swiper(".swiper", { loop: true, navigation: { nextEl: ".swiper-button-next", prevEl: ".swiper-button-prev", }, spaceBetween: 30, }); // モーダルを表示するボタンをクリックしたとき openModalBtns.forEach((openModalBtn) => { openModalBtn.addEventListener("click", () => { const modalIndex = openModalBtn.dataset.slideIndex; swiper.slideTo(modalIndex); modal.classList.add("is-active"); }); }); // モーダルを閉じるボタンをクリックしたとき closeModalBtns.forEach((closeModalBtn) => { closeModalBtn.addEventListener("click", () => { modal.classList.remove("is-active"); }); }); });

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

Lhankor_Mhy

2022/05/26 00:20

$i には何が入っていますか?
Hiroto_4431

2022/05/26 00:56

data-slide-indexにそれぞれ1,2,3,と値を入れていきたかったのでその数値を格納しています
Lhankor_Mhy

2022/05/26 06:52

スライダーは一つだけですか?

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。