как инициализировать ответ от API к переменной, чтобы я мог использовать его в моей функции render()
? Почему component.setState
не работает? Ошибка:
Uncaught TypeError: Не удается прочитать свойство 'имя пользователя' неопределенных (...)Как визуализировать данные из ответа API в React?
class Main extends React.Component {
constructor(props) {
super(props);
this.state = {
data: 23
};
}
componentDidMount() {
var component = this;
fetch('https://fcctop100.herokuapp.com/api/fccusers/top/alltime')
.then(function(response) {
return response.json()
}).then(function(json) {
var data = json;
console.log(data[0]);
console.log(data[0].username);
component.setState({
data: json
})
})
}
render() {
return (
<div>
<h1>elo{this.state.data[0].username}</h1>
</div>
);
}
}
const docs = document.getElementById('root');
ReactDOM.render(<Main/> , docs);
Вы должны иметь/тройной оператор охранник заявления в методе визуализации, если вы планируете использовать некоторые данные, которые прибывают в более позднее время. Что-то вроде этого: var someData = this.state.data [0] .username || ""; –
@JustinHerter console.logs в журналах выборки правильные данные – KAT