Зміст курсу
Опановуємо React
Опановуємо React
useState Хук
Хук useState
- це фундаментальний хук React, який дозволяє функціональним компонентам мати стан. Він надає спосіб оголошувати та оновлювати змінні стану всередині компонента.
Синтаксис:
Щоб використати хук useState
, ми викликаємо його і передаємо початковий стан (initialState
) як аргумент. Він повертає масив з двома елементами: поточне значення стану (state
) і функцію (setState
) для оновлення стану.
-
Ми можемо вибрати будь-яке слово як ім'я для змінної
state
. Рекомендується використовувати назву змінної, яка точно описує, який стан зберігається або оновлюється, наприклад,inputValue
,page
,number
,name
і так далі. -
Аналогічно, при використанні функції
setState
ми маємо гнучкість у виборі назви функції. Однак слід дотримуватися певного шаблону: ім'я функціїsetState
має починатися зі слова "set", за яким слідує ім'я відповідної змінної стану. Наприклад, якщо зміннаstate
має значенняmail
, відповідна функціяsetState
зазвичай називаєтьсяsetMail
.
Примітка
Коли ми викликаємо
setState
, React повторно рендерить компонент і оновлює стан новим значенням. Важливо зазначити, що при використанніuseState
змінна стану не обов'язково має бути об'єктом. Це може бути примітивне значення (наприклад, число, рядок або буль) або складне значення (наприклад, масив або об'єкт).
Приклад 1:
Створимо компонент Counter
, який буде підтримувати власний стан. При натисканні кнопки Increment ми будемо оновлювати стан і запускати ререндеринг компонента.
У цьому прикладі хук useState
використовується для оголошення змінної стану count
з початковим значенням 0
. Функція setCount
використовується для оновлення змінної count
при кожному натисканні кнопки.
Пояснення по рядках:
- Рядок 1: Імпортуємо хук
useState
з бібліотеки React, щоб використати його функціональність. - Рядок 3: Визначаємо компонент
Counter
, використовуючи звичайний синтаксис функцій. - Крок 4: Ініціалізуємо стан за допомогою хука
useState
.count
представляє значення лічильника. Його початкове значення0
, вказане в дужкахuseState(0)
.setCount
- функція, яка оновлює стан, коли це необхідно.
- Рядки 6-8: Ця стрілочна функція JavaScript відповідає за логіку оновлення стану. Вона виконується при натисканні кнопки "increment". Всередині функції ми використовуємо функцію
setCount
для оновлення стану. - Рядки 10-15: виводиться розмітка компонента. У рядку 12 виводиться поточне значення стану (
count
). Кнопка у рядку 13 використовує атрибутonClick
для визначення функції, яка виконується при натисканні. У цьому випадку ми передаємо функціюincrement
.
Повний код програми:
Приклад 2:
Створимо компонент Form
з незалежним станом. Запропонуємо користувачеві ввести своє ім'я в поле вводу, і в залежності від введених даних будемо змінювати вміст, що відображається.
У цьому прикладі хук useState
використовується для оголошення змінної стану userName
з початковим значенням порожнього рядка. Функція setUserName
оновлює змінну userName
щоразу, коли нам потрібно це зробити.
Пояснення по рядках:
- Рядок 1: Імпортуємо хук
useState
з бібліотеки React, щоб використовувати його функціональність. - Рядок 3: Визначаємо компонент
Form
, використовуючи стандартний синтаксис функції синтаксисом функції. - Рядок 4: Встановлюємо початковий стан за допомогою хука
useState
.userName
представляє значення поля введення, спочатку встановлене як порожній рядок (""
), вказаний у дужкахuseState("")
.setUserName
- це функція, яка дозволяє нам оновлювати стан, коли це необхідно.
- Рядки 6-9: Ця стрілочна функція JavaScript відповідає за логіку оновлення стану. Вона спрацьовує, коли користувач вводить щось у поле. Ми отримуємо вхідне значення всередині функції за допомогою
event.target.value
. Потім ми використовуємо функціюsetUserName
, щоб оновити стан значенням з поля вводу. - Рядки 11-21: Виводиться розмітка компонента.
- У рядку 15 ми призначаємо
userName
як початкове значення для введення за допомогою атрибутаvalue
. - У рядку 16 ми використовуємо атрибут
onChange
, щоб вказати функцію, яка буде викликана при зміні вхідних даних.
- У рядку 15 ми призначаємо
Повний код програми:
Дякуємо за ваш відгук!