Задать вопрос
@reivunxx

Можно ли объявлять компоненты внутри других компонентов?

Вот условно у меня есть такой по структуре код.
B - вспомогательный компонент, который например вызывается в map
у него может быть и C и D вложен внутри. И все они могут использовать родительские стейты

Вопрос собственно вот в чем: можно ли использовать такой код чтобы не плодить кучу пропсов для передачи стейтов и функций. И если нет, то хотелось бы разобраться почему.

P.s. - В реакте я новичок, поэтому буду благодарен за развернутый ответ

const A = () => {
    const [state, setState] = useState("");

    useEffect(()=>{
        setState('!')
    },[])
    
    const func = () => {
        //do something
    }

    const B = () => {
        const [stateB, setStateB] = useState(func);

        //...
        
        return <p>world{state}</p>
    }

    return <div>
        <p>Hello</p>
        <B/>
        {state}
    </div>
}
  • Вопрос задан
  • 236 просмотров
Подписаться 1 Простой 1 комментарий
Помогут разобраться в теме Все курсы
  • Яндекс Практикум
    Мидл фронтенд-разработчик
    5 месяцев
    Далее
  • Яндекс Практикум
    React-разработчик
    3 месяца
    Далее
  • Яндекс Практикум
    Фронтенд-разработчик
    10 месяцев
    Далее
Пригласить эксперта
Ответы на вопрос 1
Alexandroppolus
@Alexandroppolus
кодир
В принципе можно, но это очень плохая практика, я бы даже назвал это "антиреакт". На каждом рендере А у тебя будет абсолютно новый компонент В, значит вся его ветка будет перемонтироваться. Вместо аккуратного точечного обновления DOM, будет происходить удаление старой верстки и создание новой с нуля. Как если бы ты присвоил innerHTML. Только ещё медленнее - придется обходить удаляемое дерево, всё аккуратно размонтировать.

То есть по факту этот способ выкидывает в мусорное ведро все оптимизации, которые есть благодаря виртуальному дому.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
ITK academy Нижний Новгород
от 80 000 до 120 000 ₽
ITK academy Воронеж
от 50 000 до 90 000 ₽