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

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

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

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

jQuery

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

HTML

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

CSS

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

Q&A

2回答

681閲覧

ハンバーガーメニューが三本線→×にならない

k1a0n1a2e

総合スコア0

JavaScript

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

jQuery

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

HTML

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

CSS

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

0グッド

0クリップ

投稿2023/05/07 22:28

実現したいこと

  • ハンバーガーメニューを三本線→×に変化させたい

前提

初歩的な質問ですみません。
独学でGW中にフロントエンド言語を触り始めたばかりの初心者です。
VScodeにて、HTML,CSS,JavaScript(jQuery)のコードを記述しています。

発生している問題・エラーメッセージ

ハンバーガーメニューの三本線を×にするコードを記述したつもりだったのですが、
三本線を押しても×にならず、三本線のままです。
ハンバーガーメニューを押せば、表示されて欲しいメニューは表示されます。

該当のソースコード

html

1<link href="../css/common.css" rel="stylesheet"> 2 3<button class="toggle-menu-button"> 4 <span></span><span></span><span></span> 5</button> 6 7<script src="https://code.jquery.com/jquery-3.4.1.js" integrity="sha256-WpOohJOqMqqyKL9FccASB9O0KwACQJpFTUBLTYOVvVU=" crossorigin="anonymous"></script> 8<script src="../js/toggle-menu.js"></script>

css

1.toggle-menu-button { 2 display: block; 3 position: relative; 4 background: #fccad5; 5 cursor: pointer; 6 justify-content: center; 7 align-items: center; 8 width: 44px; 9 height: 34px; 10 border: none; 11 border-radius: 0px; 12 outline: none; 13} 14 15 /*ボタン内側*/ 16.toggle-menu-button span { 17 display: inline-block; 18 transition: all .4s; 19 position: absolute; 20 left: 12px; 21 height: 3px; 22 border-radius: 2px; 23 background: #fff; 24 width: 45%; 25} 26 27.toggle-menu-button span:nth-of-type(1) { 28 top: 7px; 29} 30 31.toggle-menu-button span:nth-of-type(2) { 32 top: 15px; 33} 34 35.toggle-menu-button span:nth-of-type(3) { 36 top: 23px; 37} 38 39 /*is-showクラスが付与されると線が回転して×に*/ 40.toggle-menu-button.is-show span:nth-of-type(1) { 41 top: 18px; 42 left: 18px; 43 transform: translateY(6px) rotate(-45deg); 44 width: 30%; 45} 46 47.toggle-menu-button.is-show span:nth-of-type(2) { 48 opacity: 0;/*真ん中の線は透過*/ 49} 50 51.toggle-menu-button.is-show span:nth-of-type(3) { 52 top: 30px; 53 left: 18px; 54 transform: translateY(-6px) rotate(45deg); 55 width: 30%; 56}

js

1window.addEventListener('load', function () { 2 var $button = document.querySelector('.toggle-menu-button'); 3 var $menu = document.querySelector('.header-site-menu'); 4 $button.addEventListener('click', function () { 5 if ($menu.classList.contains('is-show')) { 6 $menu.classList.remove('is-show'); 7 } 8 else { 9 $menu.classList.add('is-show'); 10 } 11 }); 12});

試したこと

こちらのサイトを参考にしました。
https://coco-factory.jp/ugokuweb/move01/5-2-1/

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

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

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

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

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

guest

回答2

0

javascript

1document.addEventListener('click',({target})=>{ 2 let t; 3 if(t=target.closest('.toggle-menu-button')){ 4 t.classList.toggle('is-show'); 5 } 6});

投稿2023/05/09 03:45

yambejp

総合スコア114863

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

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

0

js

1 if ($menu.classList.contains('is-show')) { 2 $menu.classList.remove('is-show'); 3 } 4 else { 5 $menu.classList.add('is-show'); 6 }

スタイルシートでは .toggle-menu-button.is-show のようにセレクタを指定しているので、このコードの $menu$button にすべきでは。

あと、contains() remove() add() ではなく $button.classList.toggle('is-show') の1行でよいでしょう。

投稿2023/05/07 22:32

編集2023/05/07 23:46
int32_t

総合スコア20890

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問