У меня есть приложение React, которое управляет своим глобальным состоянием с помощью useContext и useReducer. Моему BookList
component необходимо получить книги с сервера при установке. Если получение книг прошло успешно, они должны быть сохранены в глобальном состоянии.
Мой подход выглядит следующим образом
function BookList() {
const [state, dispatch] = useContext(BookContext);
const [loading, setLoading] = useState(true);
useEffect(() => {
BookService
.fetchBooks()
.then(resp => {
setLoading(false);
dispatch({
type: FETCH_BOOKS,
books: resp.data
});
});
}, []);
return (
<div>
{loading
? "Loading ..."
: state.books.map(book => (
<div key={book.id}>{`${book.title} - $${book.price}`}</div>))
}
</div>
);
}
Это работает, но выдает предупреждение
У React Hook useEffect отсутствует зависимость: 'dispatch'. Или ...
Мне нужно добавить dispatch
в массив зависимостей, чтобы избавиться от предупреждения, или есть лучший способ?