реагировать-асинхронная функция возвращает обещание, но не мои данные json?
Я изучаю реакцию-родной, и у меня возникает проблема. Почему получение данных о возврате из функции async возвращает обещание, но в самой асинхронной функции оно правильно возвращает массив объектов?
На componentDidMount()
я вызываю свою функцию async, которая, в свою очередь, выводит на api url:
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;
}
В console.log(json)
я получаю правильный список объектов json, и я могу получить к ним доступ с json[0].name
. Но позже console.log(data)
возвращает обещание с нечетными данными:
Promise {_40: 0, _65: 0, _55: null, _72: null}
... и я больше не могу найти свои json-объекты. Почему это? Что еще более важно, как я могу получить мои json-данные в componentDidMount()
чтобы я мог установить его как dataSource
?
Ответы
Ответ 1
Так как getData()
является обещанием, вы сможете получить данные в блоке then
следующим образом:
componentDidMount() {
this.getData()
.then((data) => {
this.setState({
dataSource:this.state.dataSource.cloneWithRows(data),
})
});
}
Ответ 2
Другой подход, похожий на исходный код вопросителя:
async componentDidMount() {
let data = await this.getData();
console.log(data);
this.setState({
dataSource:this.state.dataSource.cloneWithRows(data),
})
}