Оптимизация Frontend: отказ от GSAP в пользу CSS и Intersection Observer

Сложные анимации на GSAP могут привести к проблемам производительности, особенно на слабых ПК. Простая анимация кнопки, основанная на изменении размера и прозрачности, легко реализуется на чистом CSS с использованием transition, что снижает вес приложения и повышает плавность работы.
Оптимизация Frontend: отказ от GSAP в пользу CSS и Intersection Observer
Изображение носит иллюстративный характер

Для отслеживания видимости кнопки вместо ScrollTrigger из GSAP можно использовать библиотеку react-intersection-observer, которая предоставляет хук useInView. Этот хук позволяет просто определить, когда кнопка попадает в область видимости пользователя, и запускать анимацию. Библиотека react-intersection-observer гораздо легче, чем GSAP.

Первоначальный вариант кода с GSAP был сложным и занимал 85 строк, в то время как новый вариант, использующий CSS и react-intersection-observer, всего 36 строк. При этом, анимация также стала более гибкой и понятной для рефакторинга. Чтобы анимация срабатывала после прокрутки пользователем определенной части секции, используется контейнер, оборачивающий контент, и свойство threshold.

Для улучшения читаемости и соблюдения принципа Open/Closed, логика анимации и видимости была вынесена в контекст React, что позволяет повторно использовать логику анимации в разных частях приложения без необходимости залезать в «кишки» компонента, что делает компонент более универсальным.


Новое на сайте

19212Архитектура смыслов в профессиональной редактуре 19209Как беспрецедентный бунт чернокожих женщин в суде Бостона разрушил планы рабовладельцев? 19208Как новые поколения троянов удаленного доступа захватывают системы ради кибершпионажа и... 19207Почему мировые киберпреступники захватили рекламные сети, и как Meta вместе с властями... 19206Как фальшивый пакет StripeApi.Net в NuGet Gallery незаметно похищал финансовые API-токены... 19205Зачем неизвестная группировка UAT-10027 внедряет бэкдор Dohdoor в системы образования и... 19204Ритуальный предсвадебный плач как форма протеста в традиционном Китае 19203Невидимая угроза в оперативной памяти: масштабная атака северокорейских хакеров на... 19202Как уязвимость нулевого дня в Cisco SD-WAN позволяет хакерам незаметно захватывать... 19201Как Google разрушил глобальную шпионскую сеть UNC2814, охватившую правительства 70 стран... 19200Как простое открытие репозитория в Claude Code позволяет хакерам получить полный контроль... 19199Зачем киберсиндикат SLH платит женщинам до 1000 долларов за один телефонный звонок в... 19198Устранение слепых зон SOC: переход к доказательной сортировке угроз для защиты бизнеса
Ссылка