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

Привет Мне интересно где лучше хранить условие рендера компонента Приведу пример (выдуманный) Есть

компонент <AdultWarning user={user} />
Он рендерит сообщение про совершенолетие
Мне его нужно рендерить в нескольких местах
Если буду везде добавлять услвоие if(user.age < 18), то это дублирование - будет проблематично искать по коду и везде править (если изменится условие рендера, которое в настоящем примере может быть гораздо сложнее)
Если всегда рендерить компонент и логику рендера перенести в сам компонент, то во время изучения кода, когда кто-то наткнется, то увидит что компонент всегда рендерится, и ему нужно будет изучать еще сам компонент чтобы понять почему он не отрендерился
Как быть? Где лучше хранить и проверять условие рендера?

7 ответов

2 просмотра

Думаю твой кейс подходит под использование HOC — higher-order component Ну или просто wrapper

Bruto- Автор вопроса
Y N
Думаю твой кейс подходит под использование HOC — h...

просто в таком решении у меня выйдет очень много таких оберток, если бизнес логика достаточно сложна Пример: Все они в HOC, и потом хоп и я забыл использовать какой-то wrapper Да еще и нужно знать какой wrapper с каким использовать, где это знание держать?

Bruto
просто в таком решении у меня выйдет очень много т...

Для того, чтобы эффективно переиспользовать бизнес логику можно создавать custom hooks И комбинировать из как захочется

Bruto- Автор вопроса

function OnlyAdult({children}) { const user = useUser(); return user.age >= 18 ? children : null; }

В стоое (редакс) хранишь isAdult, все

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

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

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
Вопрос по WIN32: Насколько я понимаю то все функции win32 привязаны к объектам операционной системы. Например консоль, файл, кисть, окна итд. Следовательно функции win32 упра...
Tommy Vercetti
6
Hello, can I install macOS and run flutter on a virtual machine? Is it possible to print for iphone?
Mazones
11
кто-то пользуется компонентами rx ? как их лучше ставить, через OPM? (lazarus)
Iluha Companets
15
Дороу! У кого-нибудь есть в загашнике проверенная функция экранирования, аналог re.escape в Python? Из доки: » Escape all the characters in pattern except ASCII letters and n...
Daniil Smolyakov
9
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
В смысле более затратная? Общая стоимость владения лошадью меньше, чем автомобиля. В среднем.
Sergej R
10
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Скажите, тут нет проблемы? IMyInterface1 = interface function GetInterface2: IInterface2; ... function TMyInterface.GetInterface2: IInterface2; begin Result := TI...
Ruslan aka DUDE
18
Карта сайта