ハンバーガーメニューのページ内アンカーリンク時に自動でとじるにはどうしたら良いですか?
リンクを押すと飛ぶのですが、メニューが開きっぱなしになってしまうので
リンクを押した時に閉じるようにしたいです。
こちらをそっくりそのまま使っています。
http://stooorm.com/memo/2019/06/28/post-151/
色々試したのですがわかりません…。
ご教授願います。

回答2件
あなたの回答
tips
プレビュー
HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。
Hypertext Transfer Protocol(HTTP)の中のHTTPヘッダフィールドはHTTPの要求やレスポンスの機能しているパラメーターが含まれます。その要求もしくはレスポンスライン(メッセージの最初の一行)でメッセージヘッダを作ります。
メニューは、UIにおける仕組みであり、ユーザに機能の表示と実行する手段を与えます。
JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。
jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。
HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。
Hypertext Transfer Protocol(HTTP)の中のHTTPヘッダフィールドはHTTPの要求やレスポンスの機能しているパラメーターが含まれます。その要求もしくはレスポンスライン(メッセージの最初の一行)でメッセージヘッダを作ります。
メニューは、UIにおける仕組みであり、ユーザに機能の表示と実行する手段を与えます。
JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。
jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。
0グッド
0クリップ
投稿2020/02/25 03:24
ハンバーガーメニューのページ内アンカーリンク時に自動でとじるにはどうしたら良いですか?
リンクを押すと飛ぶのですが、メニューが開きっぱなしになってしまうので
リンクを押した時に閉じるようにしたいです。
こちらをそっくりそのまま使っています。
http://stooorm.com/memo/2019/06/28/post-151/
色々試したのですがわかりません…。
ご教授願います。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答2件
0
jQuery使っていいなら、参考先に閉じる時のコードがあるから、丸々移植して
jQuery
1 2(function ($) { 3 4 5 /* ------------------------------- */ 6 7})(jQuery); 8 9 10 /* SP menu */ 11 function toggleNav() { 12 var body = document.body; 13 var hamburger = document.getElementById('nav_btn'); 14 var blackBg = document.getElementById('nav_bg'); 15 16 hamburger.addEventListener('click', function() { 17 body.classList.toggle('nav_open'); //メニュークリックでnav-openというクラスがbodyに付与 18 }); 19 blackBg.addEventListener('click', function() { 20 body.classList.remove('nav_open'); //もう一度クリックで解除 21 }); 22 $('a').on('click', function(){ 23 body.classList.remove('nav_open'); 24 }); 25} 26toggleNav(); 27
こんな感じかな?
投稿2020/02/25 03:27
編集2020/02/25 03:32総合スコア10434
0
ベストアンサー
jQuery使っていいなら、下記の3行でOK。
js
1 /* SP menu */ 2 $("#nav_btn, #nav_bg, #navi a").on("click", function(){ 3 $("body").toggleClass("nav_open"); 4 });
投稿2020/02/25 04:53
総合スコア34367
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。