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

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

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

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

jQuery

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

HTML

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

CSS

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

解決済

JQueryでハンバーガーメニューを実装したい

datiko
datiko

総合スコア67

jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

jQuery

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

HTML

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

CSS

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

1回答

0リアクション

0クリップ

291閲覧

投稿2022/08/16 23:49

前提

WEBページのサンプルを作成しているとき、レスポンシブデザインで画面幅が狭くなったとき、JQueryでハンバーガーメニューを表示させる機能を実装しようとしたところうまく起動しなくて困っております。

実現したいこと-

  • ハンバーガーメニューを実装する。

該当のソースコード

html

<header class="fadein-first fadein-from-up"> <div class="wrap"> <img src="image/logo_green.png" class="link"> <nav class="nav-01"> <ul> <li class="link">News</li> <li class="link">About</li> <li class="link">Service</li> <li class="link">Recruit</li> <li class="link">Contact</li> </ul> </nav> <div class="hamburger"> <span class="bar bar-top"></span> <span class="bar bar-middle"></span> <span class="bar bar-bottom"></span> </div> </div> </header> <nav class="nav-02"> <ul> <li class="link">News</li> <li class="link">About</li> <li class="link">Service</li> <li class="link">Recruit</li> <li class="link">Contact</li> </ul> </nav>

css

@media (max-width: 768px) { .nav-01 { display: none; } .nav-02 { display: block; position: fixed; right: -40%; width: 40%; height: 100%; background-color: white; opacity: 0.8; padding: 7.5rem 2.5rem; z-index: 1; transition:0.7s; overflow-x: hidden; } .nav-02 ul{ display: flex; flex-direction: column; } .nav-02 ul li { margin-bottom: 2.5rem; color: #2da690; } .nav-02-active { display: block; right: 0; } .hamburger { display: block; position: relative; width: 3rem; height: 3rem; z-index: 3; } .hamburger .bar{ position: absolute; width: 2rem; height: 2px; display: block; background: #2da690; transition: 0.1s; box-sizing: border-box; } .hamburger .bar-top { top: 10px; } .hamburger .bar-middle { line-height: 1.5rem; top: 48%; } .hamburger .bar-bottom { bottom: 10px; } .hamburger.close .bar-top{ transform: rotate(45deg); top: 48%; } .hamburger.close .bar-middle{ display: none; } .hamburger.close .bar-bottom{ transform: rotate(-45deg); bottom: 48%; }

JQuery

'use strict'; $(function() { var scroll = 0; /* メインビジュアルの切り替え */ $('.img-wrap img:nth-child(n+2)').hide(); setInterval(function() { $(".img-wrap img:first-child").fadeOut(2000); $(".img-wrap img:nth-child(2)").fadeIn(2000); $(".img-wrap img:first-child").appendTo(".img-wrap"); }, 4000); /* フェードイン */ /* メインビジュアル */ $('.top p').addClass('fadein-active01'); $('header').addClass('fadein-active02'); /* メインビジュアル以下 */ $(window).scroll(function () { $('.fadein-scroll').each(function(){ var elemPos = $(this).offset().top, windowHeight = $(window).height(); scroll = $(window).scrollTop(); if (scroll > elemPos - windowHeight ) { $(this).addClass('fadein-active01'); } if (scroll > elemPos + $(this).height() || scroll < elemPos - windowHeight) { $(this).removeClass('fadein-active01'); } }); }); /* ハンバーガーメニュー */ $('.hamburger').on('click',function() { console.log("ok") $('.nav-02').toggleClass('nav-active'); $(this).toggleClass('close'); }); });

試したこと

まずハンバーガーメニューを動かすために記入したクリックアクションはエラーはでておらず動いているようです。
その後の記述、もしくは表示させる為のCSSに問題があるように思えるが何が間違えているのかわかりません。。
お分かりの方がいらっしゃいましたらご教示いただけたら幸いです。

以下のような質問にはリアクションをつけましょう

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

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

2022/08/16 23:53

こちらの質問が他のユーザーから「やってほしいことだけを記載した丸投げの質問」という指摘を受けました。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

jQuery UI

jQuery UI はjQuery公式のインターフェースライブラリであり、対話型のウェブアプリケーションを作る際に役立ちます。

jQuery

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

HTML

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

CSS

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