Задать вопрос
@Asokr

Как правильно организовать работу компонента (useEffect и вызов API)?

Здравствуйте, подскажите, как правильно построить работу компонента с вызовом API.
Вот сам код, и один из вариантов работы useEffect(), в этом случае, я в рендер получаю старый state.
В этом варианте приходит старый state

const [category, setCategory] = useState([]);

    const {id} = useParams();

    useEffect(() => {
        getCategory();
    }, [id]);  
  
    const getCategory = async () => {
        const params = { 
                    id: id 
                };
     
        const data = await API.getOne('category', params); 
        setCategory(data);
    }


Если useEffect следит за стейтом category , естественно, происходит зацикливание.
Так получается зацикливание

useEffect(() => {
        getCategory();
    }, [category]);



Вариант, который с виду работает, но компонент ререндериться два раза, что нельзя назвать решением :)
Ререндер

useEffect(() => {
        getCategory();
    }, [id]);  

    useEffect(() => {
            document.title = category.title;
    }, [category.title]);



Решение явно должно быть простое :)
Но я программист HTML , поэтому тут его не вижу..))
  • Вопрос задан
  • 101 просмотр
Подписаться 1 Простой Комментировать
Пригласить эксперта
Ответы на вопрос 1
kirbi1996
@kirbi1996
const {id} = useParams();
const [category, setCategory] = useState([]);


  
    const getCategory = async () => {
        const params = { 
                    id: id 
                };
     
        const data = await API.getOne('category', params); 
        setCategory(data);
    }


    useEffect(() => {
        getCategory();
    }, [id]);
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
18 янв. 2025, в 03:12
1000 руб./за проект
18 янв. 2025, в 00:01
500 руб./за проект
17 янв. 2025, в 23:56
10000 руб./за проект