13 votes

React-native async fonction renvoie une promesse mais pas mes données JSON?

Je suis en train d'apprendre react-native et je rencontre un problème. Pourquoi est-ce que récupérer des données en retour d'une fonction asynchrone renvoie une promesse, mais dans la fonction asynchrone elle-même, cela renvoie correctement un tableau d'objets?

Sur componentDidMount(), j'appelle ma fonction asynchrone qui à son tour effectue un appel à une url d'api :

  componentDidMount() {
    let data = this.getData();
    console.log(data);    // <-- Promise {_40: 0, _65: 0, _55: null, _72: null}
    this.setState({
      dataSource:this.state.dataSource.cloneWithRows(data),
    })  
  }

  async getData() {
    const response = await fetch("http://10.0.2.2:3000/users", {
            method: 'GET',
            headers: {
                'Accept': 'application/json',
                'Content-Type': 'application/json',
            }   
        }); 
    const json = await response.json();
    console.log(json);     // <-- (5) [Object, Object, Object, Object, Object]
    return json;
  }

Dans console.log(json), je reçois la liste correcte des objets json, et je peux y accéder avec json[0].name. Mais plus tard, console.log(data) renvoie une promesse avec des données étranges :

Promise {_40: 0, _65: 0, _55: null, _72: null}

... et je ne peux plus trouver mes objets json. Pourquoi cela? Plus important encore, comment puis-je récupérer mes données json dans componentDidMount() afin de pouvoir les définir comme dataSource ?

17voto

Anthony Ngene Points 385

Étant donné que getData() est une promesse, vous devriez être en mesure d'obtenir les données dans un bloc then comme suit :

componentDidMount() {
  this.getData()
    .then((data) => {
      this.setState({
        dataSource:this.state.dataSource.cloneWithRows(data),
      })  
    });
}

5voto

itinance Points 354

Une autre approche similaire au code original du demandeur :

async componentDidMount() {
    let data = await this.getData();
    console.log(data);    
    this.setState({
      dataSource:this.state.dataSource.cloneWithRows(data),
    })  
  }

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X