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

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

新規登録して質問してみよう
ただいま回答率
85.35%
スクロール

スクロールとは、ディスプレイスクリーン上において連続的にコンテンツが滑っていくことを指します。

JavaScript

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

jQuery

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

Q&A

解決済

2回答

2725閲覧

each function内でスクロールイベントを一回だけ発火したい。

neg404

総合スコア15

スクロール

スクロールとは、ディスプレイスクリーン上において連続的にコンテンツが滑っていくことを指します。

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2020/08/31 06:28

それぞれ .hoge がついている要素に対して 一度だけスクロールイベントを
発火したいのですが、うまくいきません。(スクロールのたびに何度も発火します。)

each function内ではどのようにすれば うまくいきますでしょうか。
アドバイスをいただけますと助かります。

$(function(){ $(window).scroll(function() { $('.hoge').each(function () { var elemPos = $(this).offset().top; var scroll = $(window).scrollTop(); var windowHeight = $(window).height(); if (scroll > elemPos - windowHeight ) { var flag = false; if(!flag){ console.log('done'); flag = true; } } }); }); });

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

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

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

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

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

m.ts10806

2020/08/31 06:33

「うまくいかない」と仰いますが「一度だけ」をやろうとしている部分はどこでしょうか。
neg404

2020/08/31 06:51

console.log('done'); の部分です。
m.ts10806

2020/08/31 06:57 編集

HTML提示されないと何とも言えませんね。要件後出しはよろしくありません。
guest

回答2

0

ベストアンサー

変数のスコープの問題もあるのでは。
$('.hoge').each(function () {の中でvar flagが宣言されているのでイベントのたびに新しく変数が宣言されます。
グローバルで宣言したほうが良いのでは。

他の'.hoge'に対して発火されなくなりました。

フラグも配列にするかなにかして「何番目の.hoge」を持っておくとか。

投稿2020/08/31 06:55

編集2020/08/31 06:59
m.ts10806

総合スコア80875

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

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

neg404

2020/08/31 07:46 編集

変数ではなく、$(this).addClass('visible');を追加して、そのクラスを持っているかを判定して発火するように出来ました。 アドバイスありがとうございました。
m.ts10806

2020/08/31 07:48

全く方向性の違う解決方法なので自身で回答を書いて自己解決にされた方が良いのでは。
guest

0

例示のソースだけでは動作確認できないのであてずっぽうですが
フラグを「$(window).scroll(」の外側にだして、グローバルに参照しては?

投稿2020/08/31 06:36

yambejp

総合スコア116724

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

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

neg404

2020/08/31 06:53 編集

eachの外側になるので、最初の'.hoge'のみ一度 発火された後 他の'.hoge'に対して発火されなくなりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問