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

В проекте на ReactJS есть некий компонент const VideoSearchResults =

({
viewType = "index",
...rest
}) => {
if (viewType === "index") {
return <IndexSearchResults {...rest} />;
}
return <VideoSearchResults {...rest} />;
};
в том же файле IndexSearchResults и VideoSearchResults два компонента свич-кейс в которых у обоих очень похожий
const IndexSearchResults = ({
// пропсы
title,
}) => {
switch (status) {
case FetchStatus.LOADING: return (title ? (
<VideoInfoOnIndexPage
// пропсы
/>
) : <VideoLoader />);
// разные кейсы в зависимости от статуса ответа от сервера
и
const VideoSearchResults = ({
// пропсы
title,
}) => {
switch (status) {
case FetchStatus.LOADING: return (title ? (
<VideoInfoOnVideoPage
// некоторые пропсы
/>
) : <VideoLoader />);
// разные кейсы в зависимости от статуса ответа от сервера
мне нужно избавиться от дублирования этих свитч кейсов в VideoSearchResults и в IndexSearchResults и сделать один, тк они похожи.
чтобы знать что рендерить внутри этого общего свич-кейса ( либо VideoInfoOnIndexPage, либо VideoInfoOnVideoPage)
у меня только один вариант if (viewType === "index") перенести в тело этого свич-кейса и там определять VideoInfoOnIndexPage или
VideoInfoOnVideoPage рендерить?

1 ответов

5 просмотров

1) Если у тебя два компонента, которые похожы только этим свич, у которого не так много кейсов, то ничего страшного нет в этом. 2) Исходя из 1) - если у тебя много кейсов в свиче, то думай над тем, чтобы вынести это в общий компонент для VideoSearchResults и IndexSearchResults. 3) Если у тебя конпоненты только названием отличаются, то сделай один общий

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

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

Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
32
А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Дорогие любители Прекрасной Джулии! Есть кто-то имеющий практический опыт построения ML для Систем Управления? Нам нужно сделать нейросеть для автоматической подстройки пара...
Roman Timo
4
С той же поддержкой Android в тулчейне, если кому интересно. На Swift Forums шло убогое обсуждение всякой херни годами, но ничего годного так и не появлялось. Пришел vgorloff ...
iMike
1
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Приветствую ребята,у меня база есть,прорешал много задач с литкода,там деревья,списки, бэктрэкинг и все остальное,что мне сейчас делать?есть может куда устроиться поработать,е...
Aקuст Lеתסuд Aקuст Lеתסuд
5
Всех приветствую. Направьте меня в нужное русло. Постепенно переписываю проект с delphi на lazarus. Приложение - обычный windows/linux клиент для бд firebird. Тут все хорошо. ...
Mishutka
5
Anybody want this chat app? If anybody interested dm  me.. Note - Firstly payment then i send you code but i will show work on gmeet.
Rayyan Ahmad
5
Карта сайта