• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Undefinde po fetch z API

0 głosów
94 wizyt
pytanie zadane 12 grudnia 2020 w JavaScript przez xFanti Obywatel (1,290 p.)

Hejka,

Chciałbym pobrać z API o przepisach informacje do danego dania. Jednak state który przechowuje dane jest undefinde. Podejrzewam że jest to spowodowane brakiem danych przy renderowaniu strony. Ktoś może mi pomóc co powinienem zastosować

 

import React,{useEffect, useState} from 'react';
import * as style from '../style/recipeInformationStyle';
const RecipeInformation = (props) => {

  const{id} = props.match.params;
  const { recipeInfo,setRecipeInfo } = useState("");

  useEffect(()=>{

    const API = `https://api.spoonacular.com/recipes/${id}/information`;

    fetch(API)
      .then((response) => {
        if (response.ok) {
          return response;
        }
        throw Error("Dont work :(");
      })
      .then((response) => response.json())
      .then((data) => {
         setRecipeInfo(data);
      });

  },[])

  

    const listIngredients = recipeInfo.extendedIngredients.map(ingredient => 
     
        <li>{ingredient.name}</li>
      
      );

    return (
      
        <style.Container>
          <style.ContainerInformation>
            <style.MainHeader>{recipeInfo.title}</style.MainHeader>
            <style.SmallHeader>{recipeInfo.dishTypes}</style.SmallHeader>
              <style.IngredientsHeader>Ingredients</style.IngredientsHeader>
              <ul>
                {listIngredients}
              </ul>
          </style.ContainerInformation>
          <style.MealImage bgImage={recipeInfo.image}>
          </style.MealImage>
        </style.Container>
      );
    
}
 
export default RecipeInformation;

 

komentarz 12 grudnia 2020 przez ScriptyChris Mędrzec (168,460 p.)

Wypisz do konsoli argument data z linii 21 - jaka wartość tam jest?

komentarz 12 grudnia 2020 przez xFanti Obywatel (1,290 p.)
Obiekt pobrany z API

2 odpowiedzi

0 głosów
odpowiedź 12 grudnia 2020 przez Wiciorny Mędrzec (186,250 p.)

Jest to spowodowane tym, że 

  fetch(API)
      .then((response) => {
        if (response.ok) {
          return response;
        }
        throw Error("Dont work :(");
      })
      .then((response) => response.json())
      .then((data) => {
         setRecipeInfo(data);
      });
 
  },[])
 

To jest kod asynchroniczny wiec działanie jego wykonuje się w tym samym czasie co reszta, wiec wywołanie twojej zmiennej następuje niezaleznie nawet od tego jaki jest rezultat działania asynchronicznego, więc w  sytuacji kiedy zasób danych np jeszcze się nie pobrał to i tak twoja zmienna zostaje np  wypisane- wiec wskazuje na undefined.

Sprawdź czy obiekt zwrotny nie zwraca przypadkiem Obietnicy/Promise i wtedy obsłuż -> resolve rozwiąż obietnice 

komentarz 12 grudnia 2020 przez xFanti Obywatel (1,290 p.)

Sorrki ale możesz mi dokładniej opisać co piwinienem zrobić, bo nie bardzo rozumiem

Sprawdź czy obiekt zwrotny nie zwraca przypadkiem Obietnicy/Promise i wtedy obsłuż -> resolve rozwiąż obietnice 

0 głosów
odpowiedź 12 grudnia 2020 przez ScriptyChris Mędrzec (168,460 p.)

Hook useEffect wywoływany jest (domyślnie) po każdym renderze komponentu (w Twoim przypadku tylko po pierwszym renderze, ponieważ przekazałeś pustą tablicę w drugim parametrze). Więc próbujesz operować na zmiennej recipeInfo zanim odpali się useEffect, a w nim fetch pobierze dane i ustawi je przez funkcję setRecipeInfo.

Przed próbą odczytu tej zmiennej powinieneś sprawdzić, czy ma oczekiwaną wartość (w Twoim przypadku, obiekt). Możesz to zrobić w bloku zwracanym z komponentu: linijki 35 - 47. Albo wywołaj tam funkcję, która w swoim ciele sprawdzi, czy ta zmienna istnieje. Możesz to też zrobić przez optional chaining.

Podobne pytania

+1 głos
2 odpowiedzi 195 wizyt
0 głosów
2 odpowiedzi 1,073 wizyt
pytanie zadane 27 listopada 2019 w JavaScript przez mariozz Nowicjusz (140 p.)

85,805 zapytań

134,588 odpowiedzi

298,788 komentarzy

56,698 pasjonatów

Advent of Code 2021

Top 15 użytkowników

  1. 494p. - rucin93
  2. 463p. - nidomika
  3. 431p. - CC PL
  4. 385p. - Whistleroosh
  5. 379p. - ScriptyChris
  6. 372p. - adrian17
  7. 340p. - TheLukaszNs
  8. 339p. - WhiskeyTaster
  9. 321p. - Argeento
  10. 318p. - Dagohar
  11. 287p. - Anonim 1794483
  12. 281p. - Klaudia
  13. 278p. - B4mbus
  14. 269p. - b0mbix
  15. 246p. - tokox
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...