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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

Q&A

解決済

1回答

747閲覧

ウィンドウサイズでメニューバーの挙動を変えたい

n0ri40

総合スコア1

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

0グッド

0クリップ

投稿2021/08/19 07:03

前提・実現したいこと

HTML/CSS、javascript初学者です。基本的なことかもしれませんが、数日悩んで解決できずにおりますのでアドバイスを頂けたらと思います。
ヘッダー部分のメニューバーをPCサイズではhoverでドロップダウン、タブレット以下のサイズではclickでドロップダウンとするナビゲーションメニューを作っています。

PCサイズ(1200px以上)の際にhoverで挙動する部分をjQueryで設定しましたが、その挙動がタブレットサイズ(1200px以下)でも活きてしまうので、タブレットサイズの時にはclickで挙動するようにしたい。

ここに質問の内容を詳しく書いてください。
(例)PHP(CakePHP)で●●なシステムを作っています。
■■な機能を実装中に以下のエラーメッセージが発生しました。

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

挙動自体はきちんと動くのですが、1回1回リロードをして読み込まないと、それぞれの挙動を失ってしまいます。

該当のソースコード

if (window.matchMedia("(min-width: 1200px)").matches) {
$(function () {
$(".dropdown-btn").hover(
function () {
$("ul:not(:animated)", this).slideDown();
},
function () {
$("ul.dropdown", this).slideUp();
}
);
});
} else {
$(function () {
$(".dropdown-btn").on(
"click",
function () {
$("ul:not(:animated)", this).slideDown();
},
function () {
$("ul.dropdown", this).slideUp();
}
);
});
}

試したこと

以下のようにresizeを使ってみましたが、構文の書き方を理解できていないのか全く動かなくなってしまいます。

$(window).on('load resize',function(){
var winWidth = $(window).width();
if(winWidth < 1200){
$('.toggle').show();
$('.dropdown').hide();
} else{
$('.toggle').hide();
$('.dropdown').show();
}
});
$('.toggle').on('click',function(){
$(this).next('li').slideToggle();
$('.open').removeClass('open');
$('dropdown').next('li').slideUp();
operner =close;
});

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

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

主な修正点

window.matchMediaの判定がアクセス時の1回しか行われていなかったので、ブレイクポイントをまたぐたびに実行させる

・ブレイクポイントをまたぐたびに、イベントにバインドされた関数を消去

clickに2つの関数はバインドできないので修正

js

1$(function () { 2 let mql = window.matchMedia("(min-width: 1200px)"); 3 4 function checkBreakPoint(mql){ 5 $(".dropdown-btn").off(); //イベントにバインドされた関数を削除 6 if (mql.matches) { 7 $(".dropdown-btn").hover( 8 function () { 9 $("ul:not(:animated)", this).slideDown(); 10 }, 11 function () { 12 $("ul.dropdown", this).slideUp(); 13 } 14 ); 15 } else { 16 $(".dropdown-btn").on("click", 17 function () { 18 if($("ul", this).css('display')==='none'){ 19 $("ul:not(:animated)", this).slideDown(); 20 }else{ 21 $("ul.dropdown", this).slideUp(); 22 } 23 }, 24 ); 25 } 26 } 27 28 checkBreakPoint(mql); //初回実行 29 mql.addListener(checkBreakPoint); // ブレイクポイントまたぐ毎に実行 30});

投稿2021/08/19 09:28

webgoto

総合スコア1293

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

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

n0ri40

2021/08/19 12:41

分かりやすい解説を含めご回答いただきありがとうございます! 教えて頂いたコードで正常に動くようになりました! 大変助かりました、ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問