Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про JavaScript: useState, initial value, React, state, lazy initialization

Что можно положить в initial value useState?

Проверяет понимание допустимых типов начального значения для хука useState в React.

Короткий ответ

В useState можно положить любое значение: примитив (число, строка, булево), объект, массив, null, undefined или функцию. Если передать функцию, React вызовет её только при первом рендере — это называется ленивой инициализацией. Нельзя передавать Promise или другие асинхронные значения напрямую.

Длинный ответ

Что можно передать в initialValue useState?

Хук useState в React принимает начальное значение состояния. Это может быть любой тип данных JavaScript: примитивы (числа, строки, булевы значения), объекты, массивы, null, undefined или даже функция. Главное правило — значение должно быть синхронным и не асинхронным (например, Promise не подойдёт).

Ленивая инициализация

Если начальное состояние требует сложных вычислений, можно передать функцию. React вызовет её только один раз при первом рендере компонента, что улучшает производительность. Например:

const [state, setState] = useState(() => {
  const initial = expensiveComputation();
  return initial;
});

Это особенно полезно, когда начальное значение получается из localStorage или API (но синхронно).

Примеры использования

  • Примитивы: useState(0), useState('hello'), useState(true)
  • Объекты: useState({ name: 'John', age: 30 })
  • Массивы: useState([1, 2, 3])
  • null/undefined: useState(null)
  • Функция: useState(() => 42)

Что нельзя передавать?

Нельзя передавать асинхронные значения, такие как Promise или результат вызова асинхронной функции. Если нужно загрузить данные с сервера, используйте useEffect для установки состояния после монтирования.

Вывод

Используйте useState с любым синхронным значением. Для дорогих вычислений применяйте ленивую инициализацию через функцию. Это стандартная практика в React для управления состоянием компонентов.

Frontend developer

tech
tech
tech
tech
tech
tech
tech
tech
tech

Ментор по Frontend

Полное сопровождение до оффера — без дорогих курсов, с оплатой после трудоустройства

Записаться на консультацию

Уровень

  • Рейтинг:

    4

  • Сложность:

    2

Навыки

  • JavaScript

    JavaScript

  • React

    React

Ключевые слова

#useState

#initial value

#React

#state

#lazy initialization

Подпишись на React Developer в телеграм

Frontend developer

tech
tech
tech
tech
tech
tech
tech
tech
tech

Ментор по Frontend

Полное сопровождение до оффера — без дорогих курсов, с оплатой после трудоустройства

Записаться на консультацию