169 похожих чатов

Как правильно спроектировать анимации в проекте? Мне надо передавать состояние анимации

из одного компонента в другой. Например, на взаимодействие с одним элементом реагируют другие.
Через локальный стейт неудобно, засоряются компоненты, плюс происходит перерисовка
Через state manager тоже не вариант, во-первых, та же перерисовка, во-вторых анимации не относятся к бизнес логике

11 ответов

8 просмотров

а какой-нибудь “контекст” не подойдет?

А с каких пор правильной архитектурой является присутствие бизнеслогики в компонентах, а вынос анимаций за их пределы? Вы сами создали себе задачу и сами же не можете придумать для неё решение

а расскажите, что у вас за кейс когда нужно передавать состоянии анимации однго компонента в другой

Andreev-Andrey Автор вопроса

Про бизнес-логику в компонентах я ничего не писал, это не правильный подход Анимации срабатывают в компонентах по триггеру, плюс мне надо передавать компонентам информацию (например, положение мыши, завершилась ли другая анимация и тд)

Не знаю как в браузере. В реакт натив анимации шарить можно. Это применяется прям везде (Свайпом выход из экрана и там анимируется несколько элементов)

Окей, моя оплошность, я до конца не уверен, но мне кажется вам стоит посмотреть в сторону обсервера

Andreev-Andrey Автор вопроса

Вопрос не про «крутилочки» и «всплывавки», я его не очень точно сформулировал. Мне надо динамически изменять положение компонентов и анимировать их при взаимодействии пользователя Для этого компонентам надо знать, что пользователь делает, какую анимацию он затриггерил и тд. Вынести это все в одну компоненту не представляется возможным

Andreev-Andrey Автор вопроса

Спасибо)

Создав отдельный синглтон-класс сервис

От реализации же зависит. const [position, setPosition] = useState([0, 0]); useEffect(() => myEvents.on(PositionChanged, setPosition), […]); return <div style={{ left: position.x, top: position.y }} /> vs const ref = useRef(null); useEffect(() => myEvents.on(PositionChanged, ([x, y]) => { ref.current.style.left = x; ref.current.style.top = y; }), […]); return <div ref={ref} />

Andreev-Andrey Автор вопроса

Спасибо

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
Всем доброго дня! Подскажите может кто использовал связку Pagebuilder + Clientsetting. Сами параметры с типом pagebuilder в модуле Clientsetting работают нормально, можно такж...
Александр Добриков
12
А почему в си некоторые вещи работают с двойными кавычками некоторые с одинарными? Нельзя было все сделать с одними или чтоб работало с разными? например чтоб выводить строки ...
.
15
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
7
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Good afternoon, I just started learning php in conjunction with mysql. I am registering a system on a local Mamp server using phpMyAdmin. It seems to be stored normally in the...
ManGo
1
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Добрый день! Такая проблема возникла, написал код на Python, который компилирует, собирает и запускает файлы .s А в случае работы нужно то же самое делать для .asm Чем эти фа...
A Mori
5
Всем привет! procedure TForm1.FormCreate(Sender: TObject); type TStartEnd = record S: Byte; E: Byte; end; var a, b: TStartEnd; begin {1} a.S := 1; {2} a.E := 2; ...
Руслан Михайлович
10
Карта сайта