Повишете нивото на управление на състоянието на вашето приложение React с Jotai: по-проста алтернатива на Redux и идеална за по-малки проекти!
Управлението на състояние в малки по мащаб проекти обикновено е лесно с помощта на кукички и подпори на React. Въпреки това, тъй като приложението се разраства и възниква необходимостта от споделяне и достъп до данни между различни компоненти, това често води до пробивно сондиране. За съжаление, пробивното пробиване може бързо да затрупа кодовата база и да въведе предизвикателства за мащабируемост.
Въпреки че Redux предлага страхотно решение за управление на състоянието, неговият API може да бъде огромен за сравнително малки проекти. За разлика от това, Jotai, минимална библиотека за управление на състояние, която използва за управление независими единици от състояния, наречени атоми състояние, елиминира предизвикателства като пробивно сондиране и позволява по-просто и мащабируемо управление на състоянието Приближаване.
Какво представлява Jotai и как действа?
Джотай е библиотека за управление на състояние, която предлага просто решение за управление на състояние за разлика от по-сложни алтернативи като Redux. Той използва независими единици на състояние, наречени атоми, за да управлява състоянието в приложението React.
В идеалния случай различни компоненти в приложението имат достъп и актуализират тези атоми с помощта на кука, предоставена от Jotai, наречена useAtom. Ето прост пример за това как да създадете атом Jotai:
импортиране {атом} от"джотай";
конст countAtom = atom(1);
За достъп и работа с атоми в Jotai можете просто да използвате useAtom кука, която, както и др Реагирайте куките, ви дава възможност за достъп и актуализиране на стойността на състояние в рамките на функционален компонент.
Ето пример за демонстриране на използването му:
импортиране {useAtom} от"джотай";
конст countAtom = atom(1);
функцияMyComponent() {
конст [count, setCount] = useAtom (countAtom);
конст увеличение = () => setCount((prevCount) => prevCount + 1);
връщане (Брой: {count}</p>
В този пример, useAtom куката се използва за достъп до countAtom атом и свързаната с него стойност. The setCount функцията се използва за актуализиране на стойността на атома и всички свързани компоненти ще бъдат автоматично повторно изобразени с актуализираната стойност.
Като задейства само засегнатите компоненти, той намалява ненужните повторни изобразявания в приложението. Този целенасочен подход към повторното изобразяване подобрява цялостната производителност на приложението.
След като сме изчерпали основите, нека изградим просто приложение To-do React, за да разберем по-добре възможностите на Jotai за управление на състоянието.
Можете да намерите изходния код на този проект тук GitHub хранилище.
Управление на състояние в React с помощта на Jotai
За да започнете, създайте приложение React. Като алтернатива можете използвайте Vite, за да настроите React проект. След като създадете основно приложение на React, продължете и инсталирайте Jotai във вашето приложение.
npm инсталирайте jotai
След това, за да използвате Jotai във вашето приложение, трябва да обвиете цялото си приложение с Доставчик компонент. Този компонент съдържа хранилището, което служи като централен център за предоставяне на атомни стойности в цялото приложение.
Освен това ви позволява да декларирате първоначалното състояние на атомите. Като обвиете приложението си с Доставчик, всички компоненти в приложението получават достъп до атомите, които сте дефинирали, и след това те могат да взаимодействат с и да актуализират състоянието чрез useAtom кука.
импортиране { Доставчик } от"джотай";
Сега увийте приложението в index.js или main.jsx както е показано по-долу.
импортиране Реагирайте от"реагира"
импортиране ReactDOM от'react-dom/клиент'
импортиране Приложение от'./App.jsx'
импортиране'./index.css'
импортиране { Доставчик } от"джотай";
ReactDOM.createRoot(документ.getElementById("корен")).render(
</Provider>
</React.StrictMode>,
)
Конфигурирайте хранилище за данни
Магазинът действа като централно хранилище за състоянието на приложението. Обикновено съдържа дефиницията на атоми, селектори и всякакви други свързани функции, необходими за управление на състоянието с помощта на Jotai.
В този случай той управлява атомите за управление на списъка с елементи за приложението To-do. В src директория, съз TodoStore.jsx файл и добавете кода по-долу.
импортиране {атом} от"джотай";
износконст TodosAtom = атом([]);
Чрез създаване и експортиране на TodosAtom, можете удобно да взаимодействате и да актуализирате състоянието на задачите в различните компоненти на приложението.
Внедрете функционалността на приложението To-Do
Сега, след като сте конфигурирали Jotai в приложението React и сте създали атом за управление на състоянието на приложението, отидете напред и създайте прост компонент за задачи, който ще обработва функциите за добавяне, изтриване и редактиране на задачите елементи.
Създайте нов компоненти/Todo.jsx файл в src указател. В този файл добавете кода по-долу:
- Импортирайте хранилището на данни и useAtom кука.
импортиране Реагирайте, {useState} от"реагира";
импортиране {TodosAtom} от„../TodoStore“;
импортиране {useAtom} от"джотай"; - Създайте функционалния компонент и добавете JSX елементите.
Компонентът изобразява прост потребителски интерфейс за управление на списък със задачи.конст Todo = () => {
връщане (
заместител =„Нова задача“
стойност={стойност}
onChange={event => setValue (event.target.value)}
/>
износпо подразбиране Да направя;
- И накрая, внедрете функциите за добавяне и изтриване на задачи.
конст [стойност, setValue] = useState('');
конст [todos, setTodos] = useAtom (TodosAtom);конст handleAdd = () => {
ако (value.trim() !== '') {
setTodos(prevTodos => [
...предишни неща,
{
документ за самоличност: Дата.сега(),
текст: стойност
},
]);
setValue('');
}
};конст handleDelete = документ за самоличност => {
setTodos(prevTodos => prevTodos.filter(да направя => todo.id !== id));
};
The handleAdd отговаря за добавянето на нов елемент от задачи към списъка с елементи. Първо проверява дали стойността на променливата не е празна. След това създава нова задача с уникален идентификатор и въведената задача като съдържание.
The setTodos след това се извиква функция, за да актуализира списъка със задачи за вършене в атома чрез добавяне на новия елемент. На последно място, стойност състояние се нулира до празен низ след операцията за добавяне.
От друга страна, handleDelete функцията отговаря за премахването на елемент от списъка със задачи. Той филтрира елемента за вършене, като използва посочения идентификатор от съществуващия списък, като използва prevTodos.filter метод. След това актуализира списъка с помощта на setTodos функция—ефективно изтриване на посочения елемент за вършене от списъка.
Използване на Jotai за управление на състояние в React приложения
Това ръководство предоставя въведение в използването на Jotai като решение за управление на състоянието. Въпреки това има други страхотни функции, като например възможността за създаване на асинхронни атоми, специално проектирани за управление на състояние, което включва асинхронни операции, като API повиквания.
Освен това можете също да създавате производни атоми, които се използват за изчисляване и извличане на стойности от съществуващи атоми, което ви позволява да управлявате сложни състояния въз основа на други части на приложението.
Като използвате тези функции за управление на състоянието, можете да създадете по-стабилни и мащабируеми React приложения.