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

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

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

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

jQuery

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

Q&A

解決済

2回答

944閲覧

JavaScriptをレスポンシブで切り替える方法

nakajima4

総合スコア11

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2019/11/15 03:12

編集2019/11/15 05:14

JavaScriptをデバイス幅に応じた調整をするにはどのようにすればよいのでしょうか。
現状560以下にした際に付与したクラスがブラウザ幅を戻してもそのままの状態になっています。

javascript

1 $(window).on('load resize', function(){ 2 var $windowWidth = window.innerWidth 3 var $breakPointA = 560; 4 var $breakPointB = 959; 5 var isMobileSize = ($windowWidth < $breakPointA); 6 var isTabletSize = ($windowWidth <= $breakPointB) && ($windowWidth > $breakPointA); 7 var isPcSize = ($windowWidth > $breakPointB); 8 9 if (isTabletSize) { 10 //560以上〜959以下の設定 11 } else if (isMobileSize) { 12 $(function() { 13 var $win = $(window), 14 $nav = $('.site-header'), 15 navPos = $nav.offset().top, 16 fixedClass = 'is-fixed'; 17 $win.on('load scroll', function() { 18 var value = $(this).scrollTop(); 19 if ( value > navPos ) { 20 $nav.addClass(fixedClass); 21 $('.entry-content').addClass('header-top-margin'); 22   } else { 23 $nav.removeClass(fixedClass); 24 $('.entry-content').removeClass('header-top-margin'); 25 } 26 }); 27}); 28 } else if (isPcSize) { 29//960以上の設定 30 } 31 32})

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

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

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

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

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

m.ts10806

2019/11/15 03:32

質問は 何でしょうか
nakajima4

2019/11/15 04:54

559px以下のサイズのみにスクリプトが効くようにしたく考えています。
m.ts10806

2019/11/15 04:57

それは「要件」であり「質問」にはなってませんよ。 何を聞きたいのかハッキリと質問本文に記載してください。
guest

回答2

0

ベストアンサー

まず、resizescrollのような「何度も呼ばれるイベント」内でイベント登録をすると、多重にイベントが登録され続けてしまうのでやめましょう。(提示されたコードはリサイズするたびにscrollイベントのコールバックに関数を重複登録し続けます)

現状560以下にした際に付与したクラスがブラウザ幅を戻してもそのままの状態になっています。

別の状況に変わった時にリセットするようなコードを書けばよいです。

js

1$(function() { 2 var $windowWidth, $breakPointA, $breakPointB, isMobileSize, isTabletSize, isPcSize; 3 var $win = $(window) 4 , $nav = $('.site-header') 5 , navPos = $nav.offset().top 6 , fixedClass = 'is-fixed'; 7 $win.on('load resize', function() { 8 $windowWidth = window.innerWidth 9 $breakPointA = 560; 10 $breakPointB = 959; 11 isMobileSize = ($windowWidth < $breakPointA); 12 isTabletSize = ($windowWidth <= $breakPointB) && ($windowWidth > $breakPointA); 13 isPcSize = ($windowWidth > $breakPointB); 14 }) 15 $win.on('load scroll', function() { 16 if (isTabletSize) { //560以上?959以下の設定 17 // ここで状態をリセットする(isMobileSize/isPcSizeの時の変更を戻す) 18 /* isTabletSize の処理 */ 19 } else if (isMobileSize) { 20 // ここで状態をリセットする(isTabletSize/isPcSizeの時の変更を戻す) 21 var value = $(this).scrollTop(); 22 if (value > navPos) { 23 $nav.addClass(fixedClass); 24 $('.entry-content').addClass('header-top-margin'); 25 } else { 26 $nav.removeClass(fixedClass); 27 $('.entry-content').removeClass('header-top-margin'); 28 } 29 } else if (isPcSize) { //960以上の設定 30 // ここで状態をリセットする(isMobileSize/isTabletSizeの時の変更を戻す) 31 /* isPcSize の処理 */ 32 } 33 }); 34}); // 大雑把なコードの組み方を提示しています。なので、そのまま動くかわかりません

投稿2019/11/16 12:01

kei344

総合スコア69364

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

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

nakajima4

2019/11/18 04:01

上記のコードを参考に、リセットするコードを追加したらうまくできました。 スクロールが変な挙動をしてる原因もわかり、イベントの登録の仕方のもためになりました。
guest

0

window幅が変わったら発火すれば良いと思います。

投稿2019/11/15 03:36

kyoya0819

総合スコア10429

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問