【React】 画面のスクロールイベントでCSSを切り替える

image

Web制作に関することをブログにしました。誰かのお役に立てれば幸いです。
画面がスクロールされたことを検知して、トップに戻るボタンが現れたり、
トップバーの背景色が変わったりなど、スクロールイベントに合わせてCSSを切り替える方法を紹介します。

useEffectについて

今回の実装では、useStateuseEffectを使います。
以前のブログuseStateについては、まとめてあるので、
今回は、useEffectについて、まとめておきたいと思います。

useEffect(() => {
    // 第一引数 ①実行したい関数
    return () => {
        // クリーンナップ処理を記述する。
    };
},[]); // 第二引数 ②関数の実行を制御する変数

useEffectはサイトがレンダリングされたタイミングで第一引数の処理を実行するHookです。
処理が実行されるタイミングは、第二引数によってコントロールすることができます。

・第二引数を記述しない ⇨ レンダリングするたびに処理を実行

・第二引数を[] ⇨ 初回レンダリング時のみ処理を実行

・第二引数を[state] ⇨ stateの更新が起こるたびに処理を実行

となります。 クリーンナップ処理は、必要な場合のみ記述するもので省略可能です。

スクロールされたことを検知する

画面を下にスクロールしたときに、CSSが切り替わる様にします。

import { useEffect, useState } from 'react'
import s from "./Test.module.css";

const [isVisible, setIsVisible] = useState(false)

const toggleVisibility = () => {
  window.scrollY > 500
    ? setIsVisible(true)
    : setIsVisible(false)
  }

useEffect(() => {
  window.addEventListener('scroll', toggleVisibility)
  return () => window.removeEventListener('scroll', toggleVisibility)
}, [])

<div
  className={isVisible ? s.test_visible : s.test}
>
〜〜〜

上の処理で、スクロールされたことを検知しているのは、
window.addEventListener('scroll', toggleVisibility)の部分です。
addEventListenerには、クリーンナップ処理が必要なので、その処理が書かれています。
スクロールされたことを検知し、toggleVisibilityの関数を実行、
条件に合えば、isVisibleが、trueに更新されます。
あとは、isVisibleによってクラス名を切り替えてやれば、CSSが変わることになります。



<参考にしたサイト>

https://zenn.dev/web_tips/articles/795b2a85fd2d97

https://developer.mozilla.org/ja/docs/Web/API/EventTarget/addEventListener


お知らせ

可茂IT塾ではFlutterインターンを募集しています!

可茂IT塾ではFlutterインターンを募集しています!

可茂IT塾ではFlutterインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More
U30可茂ITインターンハッカソン

U30可茂ITインターンハッカソン

12月28,29日開催。2日間でアプリ開発の企画から完成までを目指す!U30可茂ITインターンハッカソンを開催します。

Read More

タグ

Flutter (108)初心者向け (27)イベント (18)Google Apps Script (15)Nextjs (11)可茂IT塾 (8)Firebase (7)riverpod (6)React (6)ChatGPT (5)デザイン (5)新卒 (4)就活 (4)vscode (4)Figma (4)Dart (4)JavaScript (4)お知らせ (4)FlutterWeb (3)Prisma (3)NestJS (3)Slack (3)TypeScript (3)ワーケーション (3)インターン (3)設計 (2)線型計画法 (2)事例 (2)Image (2)File (2)Material Design (2)画像 (2)iOS (2)アプリ開発 (2)React Hooks (2)tailwindcss (2)社会人 (2)大学生 (2)RSS (1)Google (1)Web (1)CodeRunner (1)個人開発 (1)Android (1)Unity (1)WebView (1)Twitter (1)フルリモート (1)TextScaler (1)textScaleFactor (1)学生向け (1)supabase (1)Java (1)Spring Boot (1)shell script (1)正規表現 (1)パワーポイント (1)趣味 (1)モンスターボール (1)CSS (1)SCSS (1)Cupertino (1)ListView (1)就活浪人 (1)既卒 (1)保守性 (1)iPad (1)シェアハウス (1)スクレイピング (1)PageView (1)画面遷移 (1)flutter_hooks (1)Gmail (1)GoogleWorkspace (1)ShaderMask (1)google map (1)Google Places API (1)GCPコンソール (1)Google_ML_Kit (1)Vercel (1)Google Domains (1)DeepLeaning (1)深層学習 (1)Google Colab (1)Git (1)オンラインオフィス (1)オブジェクト指向 (1)クラスの継承 (1)ポリモーフィズム (1)LINE (1)Bitcoin (1)bitFlyer (1)コミュニティー (1)文系エンジニア (1)Freezed (1)permission_handler (1)flutter_local_notifications (1)markdown (1)GlobalKey (1)ValueKey (1)Key (1)アイコン (1)go_router (1)debug (1)datetime_picker (1)Apple Store Connect (1)FlutterGen (1)デバッグ (1)Widget Inspector (1)検索機能 (1)Shader (1)Navigator (1)メール送信 (1)Firebase App Distribution (1)Fastlane (1)Dio (1)CustomClipper (1)ClipPath (1)カスタム認証 (1)アニメーション (1)Arduino (1)ESP32 (1)経験談 (1)フリーランス (1)mac (1)csv (1)docker (1)GithubActions (1)Dialog (1)BI (1)LifeHack (1)ショートカット (1)Chrome (1)高校生 (1)キャリア教育 (1)非同期処理 (1)生体認証 (1)BackdropFilter (1)レビュー (1)getAuth (1)Algolia (1)コンサルティング (1)Symbol (1)

お知らせ

可茂IT塾ではFlutterインターンを募集しています!

可茂IT塾ではFlutterインターンを募集しています!

可茂IT塾ではFlutterインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More
U30可茂ITインターンハッカソン

U30可茂ITインターンハッカソン

12月28,29日開催。2日間でアプリ開発の企画から完成までを目指す!U30可茂ITインターンハッカソンを開催します。

Read More