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

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

ただいまの
回答率

88.62%

ハンバーガーメニューのリンク(ページ内)をクリックしたら閉じたい

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,612

tt_360

score 19

前提・実現したいこと

ハンバーガーメニューを初めて作った初心者です。
なんとかできたと思っったのですが、最後の最後に修正が入ってしまい困ってます。

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

ハンバーガーメニューのリンクをクリックすると、現状リンク先には飛ぶのですが、ハンバーガーメニューが閉じないという状態です。
初歩的な質問かと思いますが、わかる方教えていただけないでしょうか?お願いします!
該当する htmlとCSSとJavascriptを公開します!

該当のソースコード

<!doctype html>
<html><head>
<meta charset="utf-8">
<title>ハンバーガーメニュー</title>
<link rel="stylesheet" href="css/main.css">
<link rel="stylesheet" href="css/media640.css" media="screen and (max-width:640px)">
<script type="text/javascript" src="js/jquery-3.3.1.min.js"></script>
<script type="text/javascript" src="js/menu.js"></script>
</head>
<body>
<header class="order2">
                      <h1><img src="img/logo.gif" alt="" class="logo"></h1>
    <nav class="globalMenuSp">
                        <ul>
                            <li class="line_3 line_none">
                                <div class="menu"><a href="index.html#tenmei_catalog">カタログ</a></div>
                                    <ul class="subMenu">
                                      <li><a href="index.html#tenmei1_catalog">-&nbsp;店名1</a></li>
                                      <li><a href="index.html#tenmei2_catalog">-&nbsp;店名2</a></li>
                                      <li><a href="index.html#tenmei3_catalog1">-&nbsp;店名3</a></li>
                                      <li><a href="index.html#sale">-&nbsp;セール</a></li>
                                    </ul>
                            </li>
                            <li class="line_3">
                            <div class="menu"><a href="index.html#zaiko-shyuhin_data">在庫情報</a></div>
                                <ul class="subMenu">
                                  <li><a href="index.html#zaiko-shyuhin_data">-&nbsp;在庫状況</a></li>
                                </ul>
                            </li>
                            <li class="line_3">
                                <div class="menu"><a href="index.html#web-fax_oder">オーダー</a></div>
                                    <ul class="subMenu">
                                      <li><a href="index.html#web_oder">-&nbsp;ウェブオーダー</a></li>
                                      <li><a href="index.html#fax_oder">-&nbsp;FAXオーダーシート<br>&nbsp;&nbsp;ダウンロード</a></li>
                                    </ul>
                            </li>
                            <li class="line_3"><div class="menu2"><a href="index.html#new_transaction">新規お取引について</a></div></li>
                            <li><div class="menu2"><a href="index.html#company_outline">弊社について</a></div></li>
                            <li class="line_2"><div class="menu2" style="border: none;"><a href="index.html#otoiawase">お問い合わせ</a></div></li>
                        </ul>
                    </nav>

                    <div class="navToggle">
                        <span></span><span></span><span></span><span>menu</span>
                    </div>
</header>


</body>
</html>
@charset "utf-8";
/* CSS Document */

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,p,blockquote{margin:0;padding:0;}
h1,h2,h3,h4,h5{font-size:100%;}
ol,ul{list-style:none;}

body{
    font-family:"MS Pゴシック", Osaka, "ヒラギノ角ゴ Pro W3";
    width:100%;
    text-align: center;
    background-color:#97AF62;
}

a:link {color:#000000; text-decoration: none;} /*未訪問のリンクの色*/
a:visited {color:#000000;} /*訪問済みのリンクの色*/
a:hover {opacity: 0.5;} /*カーソルが乗っているリンクの色*/
a:active {opacity: 0.5;} /*クリック中のリンクの色*/



.clearfix:after { 
    content: "."; 
    display: block; 
    height: 0; 
    clear: both; 
    visibility: hidden;
} 


.wrapper {
  padding: 1%;
 width: 100%;
  text-align: center;
  max-width: 1280px; /* 追加:幅は最大で1280pxまで広がるようにする */
  margin: 0 auto;
}

.wrapper p {
  margin: 0;
}

.content {
  display: flex;
  padding: 20px 0;
}

.main {
  flex: 1 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 2000px;
  margin-right: 10px;
  background: #ccc;
  background: linear-gradient(to bottom, #eeeeee 0%,#B7EAE0 100%);
}
.side {
  display: flex;
  align-items: center;
  justify-content: center;
  position: -webkit-sticky;
  position: sticky;
  top: 0px;
  width: 220px;
  height: 710px;
  background: #30b298;
}


#l_main{
    background-color: #AB6D6E;
    width: 220px;
    }





aside{

}

#r_main{
    background-color: #94C6EB;
    -webkit-flex: 1;
    flex: 1;
}


/*ヘッダー*/

header{
}

h1{
    margin-bottom: 30px;
    margin-top: 10px;
}

.logo{
    width: 220px;
}


header nav {
    text-align: left;
}
header nav ul{

}

header nav ul li .menu{
    position: relative;
    padding: 10px;
    color: #000000;
    border-bottom: 1px dotted #000000;
    list-style: none;
    text-align:left;
    font-size: 0.9em;
}

header nav ul li .menu a{
    text-decoration: none;
    font-weight: bold;
}


header nav ul li .menu2{
    position: relative;
    padding: 10px;
    color: #000000;
    border-bottom: 1px solid #000000;
    list-style: none;
    text-align:left;
    font-size: 0.9em;
}

header nav ul li .menu2 a{
    text-decoration: none;
    font-weight: bold;
}


.subMenu {
    text-align: left;
}
.subMenu li {
}

.subMenu li a {
    font-size: 0.9em;
    padding: 3px 10px 3px 30px;
    text-decoration: none;
}

#nav_toggle{
    display: none;
}
.line_1{
    border-top: solid 1px #000000;
}


.line_2{
    border-bottom: solid 1px #000000;
}

.line_3{
    border-top: solid 1px #000000;
}

.line4{
    border-bottom: 1px dotted #000000;
}

.subMenu li .line_3{
    border-bottom: none;
}

.line_none{
    border-top:none;
}

/*ナビ*/

nav.globalMenuSp {
    position: fixed;
    z-index: 2;
    top: 0;
    left: 0;
    background-color:rgba(255,255,255,0.7);
    color: #000;
    text-align: center;
    transform: translateY(-100%);
    transition: all 0.6s;
    width: 95%;
    padding-left: 30px;
    height: 496px;
}

nav.globalMenuSp ul {
    margin: 0 auto;
    padding: 0;
    width: 95%;
    height: 100%;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

nav.globalMenuSp ul li {
    font-size: 1.1em;
    list-style-type: none;
    padding: 0;
    width: 95%;
}

/* 最後はラインを描かない */
nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
    /*border-bottom: none;*/
}

nav.globalMenuSp ul li a {
    display: block;
    color: #000;
    /*padding: 1em 0;*/
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
    transform: translateY(0%);
}


/*ハンバーガー用*/

.navToggle {
    display: block;
    position: fixed;    /* bodyに対しての絶対位置指定 */
    right: 13px;
    top: 12px;
    width: 42px;
    height: 51px;
    cursor: pointer;
    z-index: 3;
    background: #666;
    text-align: center;
    letter-spacing: normal;
}

.navToggle span {
    display: block;
    position: absolute;    /* .navToggleに対して */
    width: 30px;
    border-bottom: solid 3px #eee;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 6px;
}

.navToggle span:nth-child(1) {
    top: 9px;
}

.navToggle span:nth-child(2) {
    top: 18px;
}

.navToggle span:nth-child(3) {
    top: 27px;
}

.navToggle span:nth-child(4) {
    border: none;
    color: #eee;
    font-size: 9px;
    font-weight: bold;
    top: 28px;
}

/*(タップした後)CSS*/

/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
    top: 18px;
    left: 6px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2),
.navToggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}
$(function() {
    $('.navToggle').click(function() {
        $(this).toggleClass('active');

        if ($(this).hasClass('active')) {
            $('.globalMenuSp').addClass('active');
        } else {
            $('.globalMenuSp').removeClass('active');
        }
    });
});

試したこと

これをリンクをクリックしたら閉じたいのですが、いろいろなサイトのヒントをみて真似してもどうしてもできません。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

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

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

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

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

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

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

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

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • m.ts10806

    2019/01/07 10:54

    CSSはcss/media640.cssとcss/media.cssがあるようですが、提示されているのはどちらでしょうか。両方提示されたほうが再現確認もしやすいのですが。

    キャンセル

  • tt_360

    2019/01/07 11:13

    すみません。media640.cssはないです。
    消し忘れていました。ないものとして考えてください。
    申し訳ございません!

    キャンセル

  • m.ts10806

    2019/01/07 11:14

    質問は編集できるので精査をお願いします

    キャンセル

回答 2

+2

メニュー内のリンクをクリックしたら .active を解除する処理を追加します。

$('.globalMenuSp a').click(function(){
  $('.navToggle, .globalMenuSp').removeClass('active');
});

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/01/07 11:17

    閉じました!!何日かけてもできなかったのですが、助かりました!本当にありがとうございます(T_T)

    キャンセル

checkベストアンサー

+1

これでどうでしょう。

    $('.globalMenuSp a').click(function() {
        $('.navToggle').trigger('click');
    });

【.trigger() | jQuery API Documentation】
http://api.jquery.com/trigger/

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/01/07 11:35

    閉じました!!何日かけてもできなかったのですが、助かりました!本当にありがとうございます(T_T)

    キャンセル

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

  • ただいまの回答率 88.62%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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