[JavaScript, Программирование, ReactJS] Начинающим React-разработчикам: приложение со списком дел (покупок) (перевод)
Автор
Сообщение
news_bot ®
Стаж: 6 лет 9 месяцев
Сообщений: 27286
Будущих студентов курса "React.js Developer" приглашаем записаться на бесплатный демо-урок по теме "Пишем приложение на React+Redux".
А также подготовили для вас перевод полезного материала.
Если вы только начали изучать React, для отработки основных концепций этого фреймворка можно создать простое приложение. Первое, что приходит в голову, — это приложение для составления списка дел или покупок. С него и начнем. Основные концепции React изложены в официальной документации на сайте, а в предыдущих записях моего блога можно найти ссылки на другие руководства по работе с React.Запустите VS Code или любой другой редактор кода. Для создания React-приложения наберите в терминале команду:
npx create-react-app grocerylist
Затем смените директорию:
cd grocerylist
Запустите сервер:
npm start
Откройте в браузере адрес http://localhost:3000/, и вы увидите следующее окно:
Давайте посмотрим, какие элементы интерфейса нам нужно создать, и приступим к разработке.1. Сначала создадим поле для ввода пункта в список.2. Затем — кнопку для сохранения пункта.3. Наконец, создадим список для отображения пунктов с возможностью удалять пункты и помечать их как выполненные.Для разработки такого приложения нужно изучить работу с хуками, способы создания базовых форм, работу с массивами, объектами, стрелочными функциями, оператором расширения массива и пропсами.Поработаем с кодом в файле App.js. Мы будем использовать функциональные компоненты и хук useState() для определения состояния.Создадим форму:
<form onSubmit={handleSubmit}>
<input type="text" value={item} onChange={handleChange} />
<button type="submit">ADD</button>
</form>
Вот как будет выглядеть весь наш код после создания формы:
import React, { useState } from "react";
import "./App.css"
import { v4 as uuidv4 } from "uuid";
function App() {
const [item, setItem] = useState("");
const [list, setList] = useState([]);
const handleSubmit = (e) => {
const newItem = {
id: uuidv4(),
item: item,
complete: false,
};
e.preventDefault();
if (item) {
setList([...list, newItem]);
setItem("");
}
};
const handleChange = (e) => {
setItem(e.target.value);
};
return (
<div className="App">
<h1>Grocery List</h1>
<form onSubmit={handleSubmit}>
<input type="text" value={item} onChange={handleChange} />
<button type="submit">ADD</button>
</form>
</div>
);
}
export default App;
Объясним вышенаписанный код. Мы создали переменную состояния item, в которой хранится значение элемента списка, введенного пользователем. Затем мы создали еще одну переменную состояния list, в которой хранится коллекция элементов списка в виде массива.Мы создали стрелочную функцию handleChange для изменения состояния item каждый раз, когда пользователь вводит новое значение в форму. Мы изменяем состояние с помощью setItem и назначаем его в качестве целевого значения. Мы создали еще одну функцию handleSubmit для обновления массива элементов списка каждый раз, когда пользователь вводит новый пункт. У каждого пункта есть следующие свойства: уникальный id, который генерируется как UUID, item и complete. Свойство complete является логическим состоянием: если ему присвоено значение true, пункт в списке помечается как выполненный, а значение false присваивается невыполненным пунктам.Теперь создадим новый компонент Item.js. Для этого напишем такой код:
import React from "react";
import "./Item.css";
const Item = ({ id, items, list, setList, complete }) => {
const remove = (id) => {
setList(list.filter((el) => el.id !== id));
};
const handleComplete = (id) => {
setList(
list.map((item) => {
if (item.id === id) {
return {
...item,
complete: !item.complete,
};
}
return item;
})
);
};
return (
<div className="item">
<p className={complete ? "complete" : ""}>{items}</p>
<img
onClick={() => handleComplete(id)}
src="https://img.icons8.com/offices/40/000000/checked-2--v2.png"
alt="complete task"
/>
<img
onClick={() => remove(id)}
src="https://img.icons8.com/color/48/000000/trash.png"
alt="Delete"
/>
</div>
);
};
export default Item;
Чтобы удалять пункты, мы будем отфильтровывать пункт, который надо удалить, сравнивая пункты по их id. После удаления пункта остальные пункты продолжат отображаться. Чтобы помечать пункты как выполненные, мы будем перебирать все элементы массива в переменной list, сравнивать их по id и менять значение состояния complete для соответствующего элемента. Оформите приложение по своему вкусу. Можно воспользоваться стилизованными React-компонентами, которые доступны тут.Вот как будет выглядеть наше приложение:
Демоверсия приложения. Репозиторий на GitHub.Что еще можно сделать:1. Добавить локальное хранилище.2. Добавить серверную часть на основе Firebase.3. Добавить функции регистрации и входа.Предложения приветствуются :)
Узнать подробнее о курсе "React.js Developer".
Записаться на открытый урок "Пишем приложение на React+Redux".
===========
Источник:
habr.com
===========
===========
Автор оригинала: Kritika Srivastava
===========Похожие новости:
- [Программирование] kotlinx.coroutines 1.4.0: представляем StateFlow и SharedFlow (перевод)
- [Программирование, Разработка под Android] Подменяем Runtime permissions в Android
- [Программирование, Go, Микросервисы] Создаем высокопроизводительные микросервисы с помощью gRPC, Ballerina и Go (перевод)
- [Open source, Программирование, C++] Не хочется ждать в очереди? Напишем свой диспетчер для SObjectizer с приоритетной доставкой
- [Системное программирование, Интерфейсы, Разработка под Linux, Программирование микроконтроллеров] Configuring FT4232H using the ftdi_eeprom
- [Программирование, .NET, Управление персоналом, Карьера в IT-индустрии, Интервью] Заметки про интервью на разработчика
- [Системное программирование, Интерфейсы, Разработка под Linux, Программирование микроконтроллеров] Конфигурируем FT4232H c помощью утилиты ftdi_eeprom
- [Программирование, Алгоритмы, Go] Algorithms in Go: Sliding Window Pattern
- [Программирование, Java, Apache] Как создать приложение для потоковой обработки данных при помощи Apache Flink (перевод)
- [Программирование] Не решают ли программисты противоречащие задачи (архитектура кода)
Теги для поиска: #_javascript, #_programmirovanie (Программирование), #_reactjs, #_react, #_javascript, #_vebrazrabota (веб-разработа), #_beginners, #_blog_kompanii_otus._onlajnobrazovanie (
Блог компании OTUS. Онлайн-образование
), #_javascript, #_programmirovanie (
Программирование
), #_reactjs
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах
Вы не можете прикреплять файлы к сообщениям
Вы не можете скачивать файлы
Текущее время: 22-Ноя 05:45
Часовой пояс: UTC + 5
Автор | Сообщение |
---|---|
news_bot ®
Стаж: 6 лет 9 месяцев |
|
Будущих студентов курса "React.js Developer" приглашаем записаться на бесплатный демо-урок по теме "Пишем приложение на React+Redux".
А также подготовили для вас перевод полезного материала. npx create-react-app grocerylist
cd grocerylist
npm start
Давайте посмотрим, какие элементы интерфейса нам нужно создать, и приступим к разработке.1. Сначала создадим поле для ввода пункта в список.2. Затем — кнопку для сохранения пункта.3. Наконец, создадим список для отображения пунктов с возможностью удалять пункты и помечать их как выполненные.Для разработки такого приложения нужно изучить работу с хуками, способы создания базовых форм, работу с массивами, объектами, стрелочными функциями, оператором расширения массива и пропсами.Поработаем с кодом в файле App.js. Мы будем использовать функциональные компоненты и хук useState() для определения состояния.Создадим форму: <form onSubmit={handleSubmit}>
<input type="text" value={item} onChange={handleChange} /> <button type="submit">ADD</button> </form> import React, { useState } from "react";
import "./App.css" import { v4 as uuidv4 } from "uuid"; function App() { const [item, setItem] = useState(""); const [list, setList] = useState([]); const handleSubmit = (e) => { const newItem = { id: uuidv4(), item: item, complete: false, }; e.preventDefault(); if (item) { setList([...list, newItem]); setItem(""); } }; const handleChange = (e) => { setItem(e.target.value); }; return ( <div className="App"> <h1>Grocery List</h1> <form onSubmit={handleSubmit}> <input type="text" value={item} onChange={handleChange} /> <button type="submit">ADD</button> </form> </div> ); } export default App; import React from "react";
import "./Item.css"; const Item = ({ id, items, list, setList, complete }) => { const remove = (id) => { setList(list.filter((el) => el.id !== id)); }; const handleComplete = (id) => { setList( list.map((item) => { if (item.id === id) { return { ...item, complete: !item.complete, }; } return item; }) ); }; return ( <div className="item"> <p className={complete ? "complete" : ""}>{items}</p> <img onClick={() => handleComplete(id)} src="https://img.icons8.com/offices/40/000000/checked-2--v2.png" alt="complete task" /> <img onClick={() => remove(id)} src="https://img.icons8.com/color/48/000000/trash.png" alt="Delete" /> </div> ); }; export default Item; Демоверсия приложения. Репозиторий на GitHub.Что еще можно сделать:1. Добавить локальное хранилище.2. Добавить серверную часть на основе Firebase.3. Добавить функции регистрации и входа.Предложения приветствуются :) Узнать подробнее о курсе "React.js Developer".
Записаться на открытый урок "Пишем приложение на React+Redux". =========== Источник: habr.com =========== =========== Автор оригинала: Kritika Srivastava ===========Похожие новости:
Блог компании OTUS. Онлайн-образование ), #_javascript, #_programmirovanie ( Программирование ), #_reactjs |
|
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах
Вы не можете прикреплять файлы к сообщениям
Вы не можете скачивать файлы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах
Вы не можете прикреплять файлы к сообщениям
Вы не можете скачивать файлы
Текущее время: 22-Ноя 05:45
Часовой пояс: UTC + 5