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

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

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

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

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

Q&A

3回答

738閲覧

スクロールしたらメニューボタンの色を黒から白にしたい

yukishiomi

総合スコア0

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

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

0グッド

1クリップ

投稿2021/11/07 21:24

スクロールしたらメニューボタンの色を、黒から白にしたい

下記のようなコードにしたが、スクロールしても黒のままなので、なにが原因で白に変化しないのかが知りたい。

HTML

1<div class="menu-trigger" href=""> 2 <span></span> 3 <span></span> 4 <span></span> 5</div>

CSS

1.menu-trigger { 2 display: inline-block; 3 width: 36px; 4 height: 28px; 5 vertical-align: middle; 6 cursor: pointer; 7 position: fixed; 8 top: 22px; 9 right: 30px; 10 z-index: 100; 11} 12 13.menu-trigger span { 14 display: inline-block; 15 box-sizing: border-box; 16 position: absolute; 17 left: 0; 18 width: 100%; 19 height: 4px; 20 background-color: #000; 21 transition: all .5s; 22} 23.menu-trigger span:nth-of-type(1){top:0}.menu-trigger.active span:nth-of-type(1){transform:translateY(12px) rotate(-45deg)}.menu-trigger span:nth-of-type(2){top:12px}.menu-trigger.active span:nth-of-type(2){opacity:0}.menu-trigger span:nth-of-type(3){bottom:0}.menu-trigger.active span:nth-of-type(3){transform:translateY(-12px) rotate(45deg)} 24 25.bg-is-white .menu-trigger span{background-color:#fff;}

JavaScript

1 window.addEventListener("scroll", function () { 2 // ヘッダーを変数の中に格納する 3 const header = document.querySelector("menu-trigger span"); 4 // 1px以上スクロールしたらヘッダーに「scroll-nav」クラスをつける 5 header.classList.toggle("bg-is-white", window.scrollY > 1); 6 });

補足情報

こちら、案件で追加実装での内容となります。サイトの情報として、WP化してあり、jsやcssはコンパイル化していますが、コードを見やすくするために一部コンパイル化をなくして表示しております。

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

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

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

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

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

guest

回答3

0

css

1.bg-is-white .menu-trigger span{background-color:#fff;}

上記を下記に修正

css

1.menu-trigger.bg-is-white span {background-color:#fff;}

js

1 const header = document.querySelector("menu-trigger span");

上記を下記に修正

js

1 const header = document.querySelector(".menu-trigger");

JSで .menu-trigger に bg-is-white を付加/削除する。

CSSは、.menu-trigger.bg-is-white が付加されたとき span を白背景する。

蛇足

ちなみに、

js

1header.classList.toggle("bg-is-white", window.scrollY > 1);

は、下記と同じ意味になる、ということを今回初めて知った。

js

1 if (window.scrollY > 1) { 2 header.classList.add(whiteClass) 3 } else { 4 header.classList.remove(whiteClass) 5 }

JavaScriptのclassList.toggleは第2引数に条件文を入れられる | iwb.jp

投稿2021/11/08 03:39

編集2021/11/08 03:57
hatena19

総合スコア33795

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

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

0

js

1const whiteClass = "bg-is-white"; 2window.addEventListener("scroll", function() { 3 // ヘッダーを変数の中に格納する 4 const headers = document.querySelectorAll(".menu-trigger span"); 5 if (window.scrollY > 1) { 6 for (const header of headers) { 7 header.classList.add(whiteClass) 8 } 9 } else { 10 for (const header of headers) { 11 header.classList.remove(whiteClass) 12 } 13 } 14});

投稿2021/11/08 03:43

heroyct

総合スコア434

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

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

0

css

1 .bg-is-white .menu-trigger span { 2 background-color: #fff; 3 }

となっていますので、.bg-is-white.menu-triggerの親要素でなければCSSが効かないと思いますが、JavaScriptではそうはなっていないようです。
CSSを実際のHTMLに合わせて正しく書く必要があるでしょう。

また、document.querySelector(".menu-trigger span")のドット付け忘れや、document.querySelectorAllを使っていないので一つ目のspanにしかクラスがついていない問題などについても解決する必要があるでしょう。

おそらく、.bg-is-whiteを親の要素につけた方が楽だと思います。

投稿2021/11/08 03:41

Lhankor_Mhy

総合スコア36158

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

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

yukishiomi

2021/11/08 03:55

ご回答ありがとうございます。元々のハンバーガーメニューの黒色が子要素にて指定されているため、bg-is-whiteを親要素につけてもハンバーガーメニューの色は変わらないと思ったので、子要素につけていました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

アカウントをお持ちの方は

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問