Оптимизация 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, что позволяет повторно использовать логику анимации в разных частях приложения без необходимости залезать в «кишки» компонента, что делает компонент более универсальным.


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

19726Как северокорейские хакеры взломали одну из самых популярных библиотек JavaScript 19725Почему риски от подрядчиков стали главной дырой в кибербезопасности 19724Как выживший во второй мировой придумал нападение гигантского кальмара 19723Что если вселенная никогда не начиналась с точки бесконечной плотности? 19722Доживёт ли комета MAPS до субботы? 19721Квантовый процессор IBM побил сразу два рекорда — что это меняет? 19720Как северная Корея похитила $285 миллионов у Drift через предподписанные транзакции? 19719Как хакеры через одну дыру в Next.js украли ключи от 766 серверов? 19718Artemis II покинул земную орбиту и летит к луне 19717NASA показало невиданные снимки кометы 3I/ATLAS и запечатлело старт лунной миссии Artemis... 19716Сифилис появился 4000 лет назад — или его находили не там, где искали? 19715Энергетический дисбаланс земли зашкаливает, и учёные не могут это объяснить 19714Cisco закрыла две критические уязвимости с рейтингом 9.8 из 10 в системах IMC и SSM 19713Водород из хлебных крошек: реакция, которая может потеснить ископаемое топливо 19712Китайский спутник с «рукой осьминога» прошёл орбитальный тест дозаправки
Ссылка