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

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

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

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

解決済

ハンバーガーメニューのボタンをクリックして×にしたい

yudai1107
yudai1107

総合スコア2

jQuery

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

1回答

0評価

0クリップ

102閲覧

投稿2022/05/12 07:52

1やりたいこと
現在ハンバーガメニューを作成しようとしています。
その中でボタンの枠内にあるボタンを×にしたいのですが、ボタンが反応せず困っています。

2苦戦していること
最初は右も左もわからなかったのでサイトを参考にさせていただきながら、どうやって動いているのかを確認していました。
一部分を書き換えることでどのように動くか確認がしたかったのですが、動きがなくなってしまいました。
【具体的に変更した部分】
①bodyのすぐ下にあるdivをdiv class="hamberger-button"としたこと

②初めは
$(function() { $('div').click(function(){
と記載してあったものを
$(function() {
$('hamberger-button').click(function()

というふうにdivをhamberger-buttonに書き換えたこと
(このclassに対してfunctionをかけたいと思った為)

③やっている中でhambergerの定義をしていないと思ったのでlet hamberger = document.getElementById('hambeger-button');を追加したこと

HTML

<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="stylesheet.css"> <title>Document</title> </head> <body> <div class="hamberger-button"> <span class="bar1"></span> <span class="bar2"></span> <span class="bar3"></span> </div> <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js"> </script> <script src="js/practice.js"></script> </body> </html>

CSS

.hamberger-button{ position: relative; width: 100px; height: 100px; border: 10px solid #444; box-sizing: border-box; } /* 三本線のスタイルを決める */ span { display: block; width: 60px; height: 10px; background: #444; position: absolute; left: 10px; transition: all 0.5s ease; } /* 線の縦位置の調整 */ .bar1 { top: 12.5px; background-color: blue; } .bar2 { top: 35px; background-color: yellow; } .bar3 { bottom: 12.5px; background-color: red; } /* ハンバーガーメニューがクリックされたら 上の線を真ん中に移動させて45℃回転 */ .bar1.open { top: 35px; transform: rotate(45deg); } /* ハンバーガーメニューがクリックされたら 真ん中の線は透明化して見えないようにする */ .bar2.open { opacity: 0; } /* ハンバーガーメニューがクリックされたら 下の線は真ん中に移動させて-45℃回転 */ .bar3.open { top: 35px; transform: rotate(-45deg); }

jQuery

let hamberger = document.getElementById('hambeger-button'); $(function() { $('hamberger-button').click(function() { $('.bar1, .bar2, .bar3').toggleClass('open'); }) });

3自分でやってみたこと
・console.logを使ってファイルが反応しているかどうかを試した
・hambeger-buttonに違うid名を設定してjQueryを書き換えた。
・ネットで動かない原因を調べた

4何が知りたいか
①どうやったらこのボタンが作動するのか。
②①のためには自分には何の知識が足りていないのか。

よろしくお願い致します。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

jQuery

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