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

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

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

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

jQuery

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

Q&A

解決済

2回答

2611閲覧

パラメーターIDと一致するdata-target を探して表示させたい

ayuayuayu

総合スコア68

JavaScript

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

jQuery

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

0グッド

1クリップ

投稿2022/01/31 03:47

編集2022/02/01 07:28

イメージ説明
イメージ説明
パラメーターIDと一致するdata-target を探して表示させたい

画像のように一覧から画像をクリックすると画像と説明文が出で来るモーダルウィンドウを作りました。
パラメーターを取得して一致する要素を(URLで外から飛んできても)開けるようにしたいのですが
パラメーターID【paramId】と一致するdata-targetを探してそれを表示できれば完成しますが取得が上手くできません
var data = document.querySelectorAll('[data-target="'+paramId+'"]')
この探し方を試しましたが違いました、、

参考サイトはここですhttps://www.tam-tam.co.jp/tipsnote/javascript/post9911.html

<ul class="itemList"> <li> <a href="#" class="js-modal-open" data-target="modal01"><img src="img/bag1.png"></a></li> <li> <a href="#" class="js-modal-open" data-target="modal02"><img src="img/bag1.png"></a> </li> <li> <a href="#" class="js-modal-open" data-target="modal03"><img src="img/bag1.png"></a> </li> </ul> <div id="modal01" class="modal js-modal"> <div class="modal-bg js-modal-close"> </div> <div class="modal-content"> <img src="img/bag1.png"> <div>   <h3>説明</h3>    <p>テキストテキスト</p>     <a href="" class="modal-l">リンク</a>    <a href="#" class="js-modal-close bt"></a> </div> </div> </div> <div id="modal02" class="modal js-modal"> <div class="modal-bg js-modal-close"> </div> <div class="modal-content"> <img src="img/bag1.png"> <div>   <h3>説明</h3>    <p>テキストテキスト</p>     <a href="" class="modal-l">リンク</a>    <a href="#" class="js-modal-close bt"></a> </div> </div> </div>
<script> // URLのパラメータを取得 var urlParam = location.search.substring(1); // URLにパラメータが存在する場合 if(urlParam) { // 「&」が含まれている場合は「&」で分割 var param = urlParam.split('&'); // パラメータを格納する用の配列を用意 var paramArray = []; // 用意した配列にパラメータを格納 for (i = 0; i < param.length; i++) { var paramItem = param[i].split('='); paramArray[paramItem[0]] = paramItem[1]; } paramId = paramItem[1]; console.log(paramId); // パラメータidを判断する if (paramId == 'modal01') {    var target = $(paramId).data('target'); var modal = document.getElementById(target); scrollPosition = $(window).scrollTop(); $('body').addClass('fixed').css({'top': -scrollPosition}); $('.js-modal').fadeIn(); } else {  alert('違う'); } } // モーダルウィンドウを閉じる $('.js-modal-close').on('click', function(){ $("header").fadeIn(); $('body').removeClass('fixed'); window.scrollTo( 0 , scrollPosition ); $('.js-modal').fadeOut(); return false; }); </script>

元々のクリックしてモーダルウィンドウを開いていたコードはこちらです

//モーダルウィンドウを開く $('.js-modal-open').on('click', function(){ var target = $(this).data('target'); var modal = document.getElementById(target); scrollPosition = $(window).scrollTop(); $('body').addClass('fixed').css({'top': -scrollPosition}); $('.js-modal').fadeIn(); return false; });

css

/* モーダル全体(背景+本体) */ .modal{ display: none; position: fixed; top: 0; height: 100vh; width: 100%; } /* モーダル背景 */ .modal-bg{ position: absolute; height: 100vh; width: 100%; background: rgba(0, 0, 0, 0.8); } /* モーダル本体 */ .modal-content{ position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); overflow: auto; /* はみ出た部分はスクロールさせる */ height: 80%;/* これが無いと「overflow:scroll」が利かない */ width: 60%;/* これが無いと「overflow:scroll」が利かない */ background: white; } /* モーダルウィンドウ表示中に記事本体を固定 */ body.fixed { position: fixed; width: 100%; height: 100%; left: 0; }

追記

<ul class="itemList"> <li><img value="d1" data-target="#d1"src="img/bag1.png"></li> <li><img value="d2" data-target="#d2" src="img/bag1.png"> </li> <li><img value="d3" data-target="#d3"src="img/bag1.png"> </li> </ul> <dialog id="d1"> <div class="modal-bg"> <div class="modal-content"> <img src="img/bag1.png"> <div>   <h3>11111説明</h3>    <p>テキストテキスト</p>     <a href="" class="modal-l">リンク</a>    <input type="button" class="close bt"> </div> </div> </div> </dialog> <dialog id="d2"> <div class="modal-bg"> <div class="modal-content"> <img src="img/bag1.png"> <div>   <h3>222222説明</h3>    <p>テキストテキスト</p>     <a href="" class="modal-l">リンク</a> <input type="button"class="close bt">     </div> </div> </div> </dialog> <dialog id="d3"> <div class="modal-bg"> </div> <div class="modal-content"> <img src="img/bag1.png"> <div>   <h3>333333説明</h3>    <p>テキストテキスト</p>     <a href="" class="modal-l">リンク</a>    <input type="button" class="close bt"> </div> </div> </dialog>

追記css

dialog{ background: #ffffff00; top: 0; height: 122vh; width: 100%; margin: 0 0; padding: 0 0; border: none; position: fixed; z-index: 100000; } /* モーダル本体 */ .modal-content{ position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); overflow: auto; /* はみ出た部分はスクロールさせる */ height: 80%;/* これが無いと「overflow:scroll」が利かない */ width: 60%;/* これが無いと「overflow:scroll」が利かない */ background: white; z-index: 100000; } /* モーダルウィンドウ表示中に記事本体を固定 */ body.fixed { position: fixed; width: 100%; height: 100%; left: 0; background: #000000; } .modal-content img{ width:100%; } input.bt{ width: 36px; height: 36px; background: url(img/close.png) top right no-repeat; position:absolute; top:1%; right: 1%; border: none; } .modal-content div{ padding: 20px; } a.modal-l{ display:block; } ::-webkit-scrollbar { width: 10px; height: 10px; } ::-webkit-scrollbar-thumb { background: #8e8e8e; border-radius: 5px; } ::-webkit-scrollbar-track { background: #eeeeee; border-radius: 5px; } /* モーダル背景 */ .modal-bg{ position: fixed; width: 100%; height: 100%; left: 0; background: #000000d6; z-index: 1; }

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

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

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

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

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

yambejp

2022/01/31 04:02

モーダルウィンドウとはなにか定義してください 最近はchromeなどのdialogタグのこと指すことが多いですが・・・
ayuayuayu

2022/01/31 04:29

ありがとうございます。わかりやすく画像を載せました。宜しくお願い致します。
yambejp

2022/01/31 04:55

なんか勘違いされているような気もしますが、ソースを見る限りdivでつくった 疑似モーダル処理をしていますよね?それでhistory.pushStateを編集していますが モーダルのパラメータではなく、ページ自体のパラメータなのは理解されていますか? つまりwindow.openなどで開いたものならば独自のパラメータをつけられますが ページ内の一部のHTML要素にパラメータを付けるというのは無理がある話に感じます
ayuayuayu

2022/01/31 09:32

ありがとうございます、、、 私も説明が下手で、、、 ジャパスクリプトを書き換えてみました、、
yambejp

2022/01/31 09:46

そういう話ではないのですが・・・ 別ページを開くならパラメータをつけてウィンドウを開くことは可能です しかしブラウザの特性上モードレス処理になります。 擬似的にモーダルでダイアログっぽいものを開くなら、それは パラメータをつけるとかいうレベルの話ではないということです
ayuayuayu

2022/02/01 03:43

別ページを開かないならパラメーターを付ける必要がないいということでしょうか?? 別ページから飛んで来た時にも、一致する画像のモーダルウィンドウを開いて表示させときたいので パラメーターを付けることにしたのですが パラメーターを付けなくても簡単に出来るということですか、、、?? 無知ですいません、、
guest

回答2

0

ベストアンサー

ざっとこんな感じで

javascript

1<script src="https://cdnjs.cloudflare.com/ajax/libs/dialog-polyfill/0.5.6/dialog-polyfill.min.js"></script> 2<script> 3const openModal=id=>{ 4 document.querySelector(`dialog`+id)?.showModal(); 5} 6window.addEventListener('DOMContentLoaded', ()=>{ 7 let selector,t; 8 if(typeof HTMLDialogElement=="undefined"){ 9 document.querySelectorAll('dialog').forEach(x=>dialogPolyfill.registerDialog(x)); 10 } 11 document.addEventListener('click',e=>{ 12 if(selector=e.target.closest('[data-target]')?.dataset.target){ 13 document.querySelector(selector).showModal(); 14 } 15 if(t=e.target.closest('.close')){ 16 t.closest('dialog').close(); 17 } 18 }); 19 if(selector=location.hash) openModal(selector); 20}); 21window.addEventListener('hashchange',()=>{ 22 openModal(location.hash); 23}) 24</script> 25<input type="button" value="d1" data-target="#d1"> 26<input type="button" value="d2" data-target="#d2"> 27<input type="button" value="d3" data-target="#d3"> 28<dialog id="d1">1<input type="button" value="close" class="close"></dialog> 29<dialog id="d2">2<input type="button" value="close" class="close"></dialog> 30<dialog id="d3">3<input type="button" value="close" class="close"></dialog> 31<a href="#d2">d2</a>

modal外をクリックして閉じる

javascript

1<script src="https://cdnjs.cloudflare.com/ajax/libs/dialog-polyfill/0.5.6/dialog-polyfill.min.js"></script> 2<script> 3const openModal=id=>{ 4 document.querySelector(`dialog`+id)?.showModal(); 5} 6window.addEventListener('DOMContentLoaded', ()=>{ 7 let selector,t; 8 if(typeof HTMLDialogElement=="undefined"){ 9 document.querySelectorAll('dialog').forEach(x=>dialogPolyfill.registerDialog(x)); 10 } 11 document.addEventListener('click',e=>{ 12 if(t=document.querySelector('dialog[open]')){ 13 const r=e.target.getBoundingClientRect(); 14 const rx=r.x; 15 const ry=r.y; 16 const rw=r.width; 17 const rh=r.height 18 const px=e.pageX; 19 const py=e.pageY; 20 const ox=pageXOffset; 21 const oy=pageYOffset; 22 if(px<rx+ox || px>rx+ox+rw || py<ry+oy || py>ry+oy+rh){ 23 t.close(); 24 }else if(!e.target.closest('dialog')){ 25 t.close(); 26 } 27 } 28 if(selector=e.target.closest('[data-target]')?.dataset.target){ 29 document.querySelector(selector).showModal(); 30 } 31 if(t=e.target.closest('.close')){ 32 t.closest('dialog').close(); 33 } 34 }); 35 if(selector=location.hash) openModal(selector); 36}); 37window.addEventListener('hashchange',()=>{ 38 openModal(location.hash); 39}) 40</script> 41<br><br><br><br><br><br><br><br><br><br><br><br> 42<br><br><br><br><br><br><br><br><br><br><br><br> 43<br><br><br><br><br><br><br><br><br><br><br><br> 44 45<input type="button" value="d1" data-target="#d1"> 46<input type="button" value="d2" data-target="#d2"> 47<input type="button" value="d3" data-target="#d3"> 48<dialog id="d1">1<input type="button" value="close" class="close"></dialog> 49<dialog id="d2">2<input type="button" value="close" class="close"></dialog> 50<dialog id="d3">3<input type="button" value="close" class="close"></dialog> 51<a href="#d2">d2</a> 52<br><br><br><br><br><br><br><br><br><br><br><br> 53<br><br><br><br><br><br><br><br><br><br><br><br> 54<br><br><br><br><br><br><br><br><br><br><br><br> 55

投稿2022/02/01 04:35

編集2022/02/01 10:19
yambejp

総合スコア114812

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

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

ayuayuayu

2022/02/01 07:34

ありがとうございます。追記で燃せたコードでcssで修正して形になりました!! クラスmodal-bg に closeを追加して暗くなってる部分をクリックしても閉じるようにしたいのですが、その際modal-content をクリックしても閉じてしまいます。 これはz-indexのもんだいではないですよね?ジャパスクリプトを使っているのでジャパスクリプトで書かないとダメなのでしょうか、、?
yambejp

2022/02/01 07:48 編集

提示のソースは未実装のブラウザに対してpolyfillでdialogタグの標準的なモーダル処理を エミュレートしています。 chromeやedgeはネイティブにモーダル処理が可能でバックドロップ処理などもつけられますが polyfillではそこまでサポートされていないようです。 何かをクリックしたらモーダルを閉じるというのは例示したclose処理を応用すれば できると思います。モーダルの外側をクリックしたら閉じたいということでしょうか?
ayuayuayu

2022/02/02 04:21

そうなのですね。 modal外をクリックして閉じるを試したところ、思っていた動きになりました。 ありがとうございます。 最後に一つお聞きしたいのですが、モーダルを開いたときにモーダルの中身のスクロール位置が下からになってしまうのはジャパスクリプトが関係しているのでしょうか、、?
ayuayuayu

2022/02/03 04:27

$('dialog').scrollTop(0); で出来ました。色々とありがとうございました!!!
guest

0

history.pushState()でのURL変更は、ページに何の変更ももたらさないです。
history.backなどでpopstateなどを発火させればワンチャンあるかもですが、明らかに筋が悪いので諦めて、とりあえず、元のコードに戻すことをおすすめします。URLの処理と、モーダルの処理は別々に面倒を見た方がいいでしょう。

そして、URLで外から飛んできた場合は、urlParamを参照してdata-targetを探し、その要素を.click()した方が早いでしょう。

投稿2022/01/31 06:26

Lhankor_Mhy

総合スコア36080

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

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

ayuayuayu

2022/01/31 09:31

有難う御座います。history.pushState()やめて ジャパスクリプトをかきかえてみました。 // パラメータidを判断するのところでdata-target を探す書き方がわからなくて modal01 と書いてありますが paramId と一致するdivが開ければ完成するところです、、、 模索中です、、、
ayuayuayu

2022/02/01 04:31

data-target を探すのに var modal = document.getElementById(paramId); は違いますか? なかなか一致するのをさがせなくて、、
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問