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

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

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

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

HTML5

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

WordPress

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

PHP

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

モーダルダイアログ

モーダルダイアログとは、ユーザーに重要な情報を表示するときに用いられる視覚的なダイアログのことを指します。これらのダイアログは他のすべてのコンテンツの上に表示され、ユーザーの入力を受けるまでアプリケーションフローは停止されます。

解決済

1つの画面にモーダルウィンドウのリンクを2つ置き、それぞれ違うコンテンツを表示できない

tuki43
tuki43

総合スコア12

CSS3

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

HTML5

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

WordPress

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

PHP

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

モーダルダイアログ

モーダルダイアログとは、ユーザーに重要な情報を表示するときに用いられる視覚的なダイアログのことを指します。これらのダイアログは他のすべてのコンテンツの上に表示され、ユーザーの入力を受けるまでアプリケーションフローは停止されます。

2回答

0リアクション

0クリップ

200閲覧

投稿2022/08/16 07:28

前提

1つの画面にモーダルウィンドウのリンクを2個置き、それぞれコンテンツの異なるものを用意したのですが表示させたいのですがうまくいきません。※環境はWordPress上です

呼び出し元のaタグにdata-target="modal1" data-target="modal2"を設け、
モーダルのコンテンツのほうではdivタグにid="modal1"、id="modal2"のようにし、data-target=modal1が選択されたらコンテンツ id="modal1"を表示、modal2が選択されたらコンテンツ id="modal2"を表示させたいです。

現状では両方とも画面が開いてしまい、どうやって切り分けたらよいのか分からずご教授願います。

jsのほうで var modal = '#' + $(this).attr('data-target');
でdata-targetの値は取れたのですが、ここからif文をかましてinnerHTMLするのでしょうか?
それだと不便といいますか、初めからphpのほうにコンテンツ内容を表示させておきたいです。

コンテンツの内容は特に難しい処理はなく、テキストと画像を載せるだけのものです。

実現したいこと

それぞれのコンテンツを表示させたい。

該当のソースコード

php

functions.php  <div class="bouhan-box">   <p><a data-target="modal1" class="modal-open reset">〇〇1について</a></p>  <p><a data-target="modal2" class="modal-open reset">〇〇2について</a></p>  </div> <!-- モーダル本体1 --> <div id="modal1" class="modal-container"> <div class="modal-body"> <!-- 閉じるボタン --> <div class="modal-close">X</div> <!-- モーダル内のコンテンツ -->  <div class="modal-content">  <p>〇〇1について</p>  <img src="<?php echo get_stylesheet_directory_uri() ?>/images/xxx.jpg" alt="〇〇1について">      </div>   </div> </div> <!-- モーダル本体2 --> <div id="modal2" class="modal-container"> <div class="modal-body"> <!-- 閉じるボタン --> <div class="modal-close">X</div> <!-- モーダル内のコンテンツ --> <div class="modal-content">   <p>〇〇2について</p>      <img src="<?php echo get_stylesheet_directory_uri() ?>/images/yyy.jpg" alt="〇〇1について">    </div> </div> </div>

jsファイル

$(function () { // 変数に要素を入れる var open = $('.modal-open'), close = $('.modal-close'), container = $('.modal-container'), scroll_position = 0; // 開くボタンをクリックしたらモーダルを表示する open.on('click', function () { // スクロール固定 scroll_position = $(window).scrollTop(); container.addClass('active'); $('body').addClass('fixed').css({ 'top': -scroll_position }); // data-targetの内容をIDにしてmodalに代入 var modal = '#' + $(this).attr('data-target');      // ここでInnerHTML?      if(modal == 'modal1'){ }else if(modal == 'modal2'){ } return false; }); //閉じるボタンをクリックしたらモーダルを閉じる close.on('click', function () { container.removeClass('active'); $('body').removeClass('fixed').css({ top: 0 });//背景固定を解除 $(window).scrollTop(scroll_position);//元の位置までスクロール return false;//<a>を無効化 }); //モーダルの外側をクリックしたらモーダルを閉じる $(document).on('click', function (e) { if (!container.hasClass('active')) { return; } if (!$(e.target).closest('.modal-body').length) { container.removeClass('active'); $('body').removeClass('fixed').css({ top: 0 });//背景固定を解除 $(window).scrollTop(scroll_position);//元の位置までスクロール return false;//<a>を無効化 } }); })

試したこと

ここに問題に対して試したことを記載してください。

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

ここにより詳細な情報を記載してください。

以下のような質問にはリアクションをつけましょう

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

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

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

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

適切な質問に修正を依頼しましょう。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

CSS3

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

HTML5

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

WordPress

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

PHP

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

モーダルダイアログ

モーダルダイアログとは、ユーザーに重要な情報を表示するときに用いられる視覚的なダイアログのことを指します。これらのダイアログは他のすべてのコンテンツの上に表示され、ユーザーの入力を受けるまでアプリケーションフローは停止されます。