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

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

新規登録して質問してみよう
ただいま回答率
85.48%
jQueryプラグイン

jQueryの拡張機能。 様々な種類があり、その数は膨大です。公開済みのプラグインの他にも、自作することもできます。 jQueryで利用できるようにしておくだけで、導入およびカスタマイズが比較的容易に行なえます。

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

解決済

1回答

1805閲覧

バーガーメニューを閉じた時、中のアコーディオンも閉じる

momoko_888

総合スコア2

jQueryプラグイン

jQueryの拡張機能。 様々な種類があり、その数は膨大です。公開済みのプラグインの他にも、自作することもできます。 jQueryで利用できるようにしておくだけで、導入およびカスタマイズが比較的容易に行なえます。

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クリップ

投稿2020/08/05 03:42

編集2020/08/05 03:55

前提・実現したいこと

はじめまして。

現在meanmenuというレスポンシブ対応のドロワーメニューを使用しています。
うぇぶもようさんのサイト(https://webmoyou.com/web/703/)を参考にさせていただきました。

ドロワーの中にドロップダウン(アコーディオン)がありますが、ドロップダウンを開いたままクローズボタン(meanmenu-reveal)をクリックしたら、次にドロワーオープンしたときに閉じていて欲しいです。(現状は開けたままクローズすると次もドロップダウンは開いたままです。)

該当のソースコード

Javascript

1 $(function() { 2 //メニューの表示状態保管用 3 var state = false; 4 //.bodyのスクロール位置 5 var scrollpos = 0; 6 //meanmenuの状態による表示制御 7 function mm_control() { 8 if($('.mean-nav .nav').is(':visible')) { 9 //表示中 10 if(state == false) { 11 scrollpos = $(window).scrollTop(); 12 $('body').addClass('fixed').css({'top': -scrollpos}); 13 $('.mean-container').addClass('open'); 14 $('.mean-nav .mask').show(); 15 state = true; 16 } 17 } else { 18 //非表示中 19 if(state == true) { 20 $('body').removeClass('fixed').css({'top': 0}); 21 window.scrollTo( 0 , scrollpos ); 22 $('.mean-container').removeClass('open'); 23 $('.mean-nav .mask').hide(); 24 state = false; 25 } 26 } 27 } 28 29 $('#gNav').meanmenu({ 30 meanMenuContainer: "#header .h_nav", // メニューを表示させる位置 31 meanScreenWidth: "768" 32 }); 33 34 $(document) 35 .on('opend.meanmenu closed.meanmenu', function() { 36 mm_control(); 37 }) 38 .on('touchend click', '.mean-bar .mask', function(e) { 39 $('.mean-bar .meanmenu-reveal').trigger('click'); 40 return false; 41 }); 42 43 //ウィンドウサイズ変更によるメニュー非表示時の制御 44 $(window).on('resize', function() { 45 mm_control(); 46 }); 47 });

試したこと

Javascript

1//非表示中 2if(state == true) { 3 $('body').removeClass('fixed').css({'top': 0}); 4 window.scrollTo( 0 , scrollpos ); 5 $('.mean-container').removeClass('open'); 6 //追加した箇所 7 $(".mean-expand").toggleClass("mean-clicked",false).text('+'); 8 $('.sub-menu').css('display','none'); 9 //追加した箇所終了 10 $('.mean-nav .mask').hide(); 11 state = false; 12}

上記2行を追加しましたが、これだとPCにリサイズした際のドロップダウンは非表示になってしまいます・・・。

if(!navigator.userAgent.match(/(iPhone|iPad|iPod|Android)/)){}
で上記を囲ったりもしてみましたが、うまくいきません。

また、表示をかえるだけでは無理なのかもしれないと思ったので

Javascript

1//非表示中 2if(state == true) { 3 $('body').removeClass('fixed').css({'top': 0}); 4 window.scrollTo( 0 , scrollpos ); 5 $('.mean-container').removeClass('open'); 6 //追加した箇所 7$(".mean-expand").trigger('click'); 8 //追加した箇所終了 9 $('.mean-nav .mask').hide(); 10 state = false; 11}

上記も試してみましたが、なぜかクローズしたときにトップへスムーススクロールしてしまい、うまくいきませんでした。(スムーススクロールの動きもサイトにあります。)

スキル不足で恐縮ではございますが、ご教授いただけますと幸いです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

初めに貼ってあるソースコードの //表示中 までを下記のようにすることでおkだと思います。
私は素人ですので、どこかに不具合が出てる可能性もあります。アロー関数を使ってるので
IE11では動かないのでそこはjqueryにするなり書き換えることで対応してください。

Javascript

1 $(function ($) { 2 //メニューの表示状態保管用 3 var state = false; 4 //.bodyのスクロール位置 5 var scrollpos = 0; 6 //meanmenuの状態による表示制御 7 function mm_control() { 8 if ($('.mean-nav .nav').is(':visible')) { 9 10 const closeAccordion = (elm) => { 11 elm.addEventListener("click", () => { 12 const closeElm = document.getElementsByClassName("mean-expand"); 13 for (let i = 0; i < 2; i++) { 14 if (closeElm[i].classList.contains("mean-clicked")) { 15 closeElm[i].click(); 16 } 17 } 18 }); 19 } 20 21 const mask = document.getElementsByClassName("mask")[0]; 22 const closeBtn = document.getElementsByClassName("meanclose")[0]; 23 24 closeAccordion(mask); 25 closeAccordion(closeBtn); 26 27 //表示中

投稿2020/08/05 09:05

Jon_do

総合スコア1373

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

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

momoko_888

2020/08/05 10:59

Jon_do様 ご回答いただきありがとうございます!ご教授いただいたソースで無事希望の動きが実装できました;: 本当にありがとうございます!
momoko_888

2020/08/05 11:04 編集

MEMO: 希望の動きは実装できたのですが、クローズボタンを押すとTOPまで戻るという現象が発生しておりました。原因は、スムーススクロールのJSが競合を起こしていました。 Jon_do様からご教授いただいたソースはそのままに、スムーススクロールのJSの方に$('a[href^="#"]:not(.mean-expand)').click(function(){〜略 を追記しました。(.mean-expandもaタグなので、競合したのかもしれない?)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問