Ssylka

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


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

18964Хаббл запечатлел крупнейший в истории наблюдений хаотичный протопланетный диск 18963Почему открытые телескопом «Джеймс Уэбб» «галактики-утконосы» ломают представления об... 18962Революционные космические открытия, пересмотр колыбели человечества и радикальные реформы... 18961Уникальный костяной стилус V века до нашей эры с изображением Диониса найден на Сицилии 18960Скрытый механизм защиты желудка от кислотного самопереваривания 18959Масштабная ликвидация испанской ячейки нигерийского преступного синдиката Black Axe 18958Китайские хакеры реализовали полный захват гипервизора VMware ESXi через уязвимости... 18957Анализ ископаемых зубов из Дманиси опровергает теорию о первенстве Homo erectus в... 18956Чем гигантское солнечное пятно AR 13664 спровоцировало мощнейшую бурю за 21 год и скрытый... 18955Крошечный костный выступ подтвердил прямохождение древнейшего предка человека возрастом... 18954Гендерный парадокс и социальная истерия во время первой дипломатической миссии самураев в... 18953Расследование гибели древнего добытчика бирюзы в пустыне Атакама 18952Противостояние Юпитера 10 января открывает сезон лучших астрономических наблюдений 18951Реформа кибербезопасности США через отмену устаревших директив CISA 18950Почему критическое обновление Trend Micro Apex Central требует немедленной установки?