【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


お知らせ

3月19日開催のアプリ開発講座の参加者募集中!!

3月19日開催のアプリ開発講座の参加者募集中!!

3月19日にアプリ開発講座を開催します!会場は岐阜県美濃加茂市のコワーキングスペース「こやぁね」です。興味のある方は是非ご参加ください!

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

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

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

Read More

タグ

Flutter (70)初心者向け (22)イベント (15)Nextjs (8)Google Apps Script (7)可茂IT塾 (6)Firebase (6)React (5)新卒 (3)就活 (3)給与支払報告書 (3)riverpod (3)Dart (3)JavaScript (3)TypeScript (3)インターン (3)FlutterWeb (2)画像 (2)アプリ開発 (2)React Hooks (2)tailwindcss (2)ワーケーション (2)社会人 (2)大学生 (2)お知らせ (2)webfeed (1)RSS (1)CodeRunner (1)VSCode (1)個人開発 (1)設計 (1)フルリモート (1)学生向け (1)Java (1)Spring Boot (1)エンジニア (1)DeviceOrientation (1)正規表現 (1)神楽 (1)趣味紹介 (1)プログラミングだけではない可茂IT塾のメンバー (1)線型計画法 (1)事例 (1)PreferredSize (1)マテリアルデザイン (1)Material (1)クパチーノデザイン (1)Cupertino (1)ListView (1)就活浪人 (1)既卒 (1)保守性 (1)シェアハウス (1)スクレイピング (1)Gmail (1)Googleグループ (1)GoogleWorkspace (1)ShaderMask (1)google map (1)Google Places API (1)Vercel (1)Google Domains (1)branch (1)Git (1)オンラインオフィス (1)Freezed (1)アイコン (1)Apple Store Connect (1)FlutterGen (1)検索機能 (1)Navigator (1)メール送信 (1)カスタム認証 (1)アニメーション (1)FloatingActionButton (1)Arduino (1)ESP32 (1)経験談 (1)フリーランス (1)Dialog (1)Figma (1)デザイン (1)Slack (1)BI (1)非同期処理 (1)BackdropFilter (1)iOS (1)レビュー (1)getAuth (1)匿名 (1)Algolia (1)chakra-ui (1)コンサルティング (1)Symbol (1)reactive_forms (1)

お知らせ

3月19日開催のアプリ開発講座の参加者募集中!!

3月19日開催のアプリ開発講座の参加者募集中!!

3月19日にアプリ開発講座を開催します!会場は岐阜県美濃加茂市のコワーキングスペース「こやぁね」です。興味のある方は是非ご参加ください!

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

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

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

Read More