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

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

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

SCSSは、SassのCSSメタ言語です。Webページのスタイルを指定するCSSを効率的に記述することができます。ネストと呼ばれる入れ子構造で記述するため、CSSの全体の記述量を減らせる点が特徴です。さらに変数も利用できるため、変更や修正の際に少ない作業量で対応することもできます。

HTML5

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

JavaScript

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

CSS

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

Q&A

解決済

1回答

758閲覧

JavaScript, SCSSでモーダルを実装したい

pay_561

総合スコア26

SCSS

SCSSは、SassのCSSメタ言語です。Webページのスタイルを指定するCSSを効率的に記述することができます。ネストと呼ばれる入れ子構造で記述するため、CSSの全体の記述量を減らせる点が特徴です。さらに変数も利用できるため、変更や修正の際に少ない作業量で対応することもできます。

HTML5

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

JavaScript

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

CSS

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

0グッド

0クリップ

投稿2021/11/09 11:07

困っていること

モーダルをを実装したいのですがエラーも表示されていなくてわかりません

ご教授いただけたら幸いです。

コード

index.html

<div id="modal" class="modal"> <span id="modal-close" class="close">&times;</span> <img id="modal-content" class="modal-content" /> <div class="more-images"> <div class="more-images-item"> <img class="img-preview" /> </div> <div class="more-images-item"> <img class="img-preview" /> </div> <div class="more-images-item"> <img class="img-preview" /> </div> <div class="more-images-item"> <img class="img-preview" /> </div> </div> </div>

index.scss

.modal { display: none; position: fixed; z-index: 100; padding-top: 100px; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgb(0, 0, 0); background-color: rgba(0, 0, 0, 0.9); .close { position: absolute; top: 15px; right: 35px; color: $white; font-size: 40px; font-weight: 900; transition: 0.3s; &:hover, focus { color: $silver; text-decoration: none; cursor: pointer; } } .modal-content { margin: auto; display: block; width: 80%; max-width: 700px; animation-name: zoom; animation-duration: 0.6s; } @keyframes zoom { from { transform: scale(0); } to { transform: scale(1); } } }

index.js

let modal = document.getElementById("modal"); let closeBtn = document.getElementById("modal-close"); closeBtn.onclick = () => { modal.style.display = "none"; }; let moreImages = document.getElementsByClassName("more-images-item"); let previewImages = document.getElementsByClassName("img-preview"); Array.from(moreImages).forEach((e) => { e.onclick = () => { let imgItems = e.parentNode.getElementsByTagName("img"); Array.from(imgItems).forEach((item, index) => { previewImages[index].src = item.src; }); let img = e.querySelector("img"); modal.style.display = "block"; let modalContent = modal.querySelector(".modal-content"); modalContent.src = img.src; let temp = modalContent.cloneNode(true); modalContent.parentNode.replaceChild(temp, modalContent); }; });

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

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

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

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

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

guest

回答1

0

ベストアンサー

コードから推測すると、
やりたいことは、
.more-images-item をクリックしたらモーダル(#modal)が開き、そこにクリックした画像を表示させたい、
でしょうか。

だとしたら、more-imageクラスの要素をmodalクラスの外に出せばいいでしょう。

html

1<div id="modal" class="modal"> 2 <span id="modal-close" class="close">&times;</span> 3 <img id="modal-content" class="modal-content" src=""> 4</div> 5<div class="more-images"> 6 <div class="more-images-item"> 7 <img class="img-preview" src="image1.png"> 8 </div> 9 <div class="more-images-item"> 10 <img class="img-preview" src="image2.png"> 11 </div> 12 <div class="more-images-item"> 13 <img class="img-preview" src="image3.png"> 14 </div> 15 <div class="more-images-item"> 16 <img class="img-preview" src="image4.png"> 17 </div> 18</div>

投稿2021/11/09 12:54

hatena19

総合スコア33795

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

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

pay_561

2021/11/10 02:59

ありがとうございます。 解決しました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問