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

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

新規登録して質問してみよう
ただいま回答率
85.48%
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スクリプトは「サーバサイドスクリプト」と呼ばれています。

モーダルダイアログ

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

Q&A

解決済

2回答

580閲覧

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

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スクリプトは「サーバサイドスクリプト」と呼ばれています。

モーダルダイアログ

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

0グッド

0クリップ

投稿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

1functions.php 2 3 <div class="bouhan-box"> 4   <p><a data-target="modal1" class="modal-open reset">〇〇1について</a></p> 5  <p><a data-target="modal2" class="modal-open reset">〇〇2について</a></p> 6 </div> 7<!-- モーダル本体1 --> 8<div id="modal1" class="modal-container"> 9 <div class="modal-body"> 10 <!-- 閉じるボタン --> 11 <div class="modal-close">X</div> 12 <!-- モーダル内のコンテンツ --> 13  <div class="modal-content"> 14  <p>〇〇1について</p> 15  <img src="<?php echo get_stylesheet_directory_uri() ?>/images/xxx.jpg" alt="〇〇1について"> 16     </div> 17   </div> 18 </div> 19 <!-- モーダル本体2 --> 20 <div id="modal2" class="modal-container"> 21 <div class="modal-body"> 22 <!-- 閉じるボタン --> 23 <div class="modal-close">X</div> 24 <!-- モーダル内のコンテンツ --> 25 <div class="modal-content"> 26   <p>〇〇2について</p> 27     <img src="<?php echo get_stylesheet_directory_uri() ?>/images/yyy.jpg" alt="〇〇1について"> 28    </div> 29 </div> 30</div> 31

jsファイル

1 $(function () { 2 3 // 変数に要素を入れる 4 var open = $('.modal-open'), 5 close = $('.modal-close'), 6 container = $('.modal-container'), 7 scroll_position = 0; 8 9 10 // 開くボタンをクリックしたらモーダルを表示する 11 open.on('click', function () { 12 13 // スクロール固定 14 scroll_position = $(window).scrollTop(); 15 container.addClass('active'); 16 $('body').addClass('fixed').css({ 'top': -scroll_position }); 17 18 // data-targetの内容をIDにしてmodalに代入 19 var modal = '#' + $(this).attr('data-target'); 20 21     // ここでInnerHTML? 22     if(modal == 'modal1'){ 23 24 }else if(modal == 'modal2'){ 25 } 26 27 return false; 28 }); 29 30 //閉じるボタンをクリックしたらモーダルを閉じる 31 close.on('click', function () { 32 container.removeClass('active'); 33 $('body').removeClass('fixed').css({ top: 0 });//背景固定を解除 34 $(window).scrollTop(scroll_position);//元の位置までスクロール 35 return false;//<a>を無効化 36 }); 37 38 //モーダルの外側をクリックしたらモーダルを閉じる 39 $(document).on('click', function (e) { 40 if (!container.hasClass('active')) { 41 return; 42 } 43 if (!$(e.target).closest('.modal-body').length) { 44 container.removeClass('active'); 45 $('body').removeClass('fixed').css({ top: 0 });//背景固定を解除 46 $(window).scrollTop(scroll_position);//元の位置までスクロール 47 return false;//<a>を無効化 48 } 49 }); 50 }) 51

試したこと

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

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

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

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

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

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

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

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

guest

回答2

0

サンプルコードを書いているうちに自己解決したようですが、

activeクラスの付加/除去で表示/非表示をしているのなら(closeボタンのコード等から推測)、
下記のコードで両方のモーダルにactiveクラスを追加しているために、両方表示されるので、

js

1 container.addClass('active');

これをクリックしたボタンの data-target の id のモーダルのみにactiveクラスを追加するように修正すればいいだけです。

js

1$('#' + $(this).attr('data-target')).addClass('active');

投稿2022/08/16 08:39

編集2022/08/16 12:58
hatena19

総合スコア33715

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

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

tuki43

2022/08/16 12:49

ありがとうございます!さっそく試してみますね。
tuki43

2022/08/17 09:02

こちらの方法で実装させていただきました。 他のページでは container.addClass('active'); を使っていましたので、pathnameでif文かましました。
guest

0

自己解決

自己解決できました!Display blockすれば切り替えできるんじゃないかと思って試したら出来ました!

const m1 = document.getElementById("modal1");
const m2 = document.getElementById("modal2");
// data-targetの内容をIDにしてmodalに代入
var modal = '#' + $(this).attr('data-target');
if(modal == '#modal1'){
m2.style.display = "none";
m1.style.display = "block";
}else if(modal == '#modal2'){
m1.style.display = "none";
m2.style.display = "block";
}

投稿2022/08/16 08:02

tuki43

総合スコア12

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問