Я делаю простой запрос AJAX с API-интерфейсом выборки в React, в частности, в функции componentDidMount()
.
Это работает, потому что консоль записывает результат. Однако я не знаю, как получить доступ к ответу...
componentDidMount = () => {
let URL = 'https://jsonplaceholder.typicode.com/users'
fetch(URL)
.then(function(response) {
let myData = response.json()
return myData;
})
.then(function(json) {
console.log('parsed json', json)
})
.catch(function(ex) {
console.log('parsing failed', ex)
})
} // end componentDidMount
Я попытался получить доступ к myData
вне метода выборки, но это выдает ошибку о том, что он не определен. Таким образом, он доступен только в рамках функции.
Затем я попробовал это:
.then(function(response) {
let myData = response.json()
// return myData;
this.setState({
data: myData
})
})
На этот раз я получаю Cannot read property 'setState' of undefined(…)
Как передать ответ на выборку в состояние или даже просто в глобальную переменную?
ОБНОВИТЬ
import React, { Component } from 'react';
import './App.css';
class App extends Component {
constructor(props) {
super(props);
this.state = {
data: null
}
}
componentDidMount() {
let URL = 'https://jsonplaceholder.typicode.com/users'
fetch(URL)
.then( (response) => {
let myData = response.json()
// return myData;
this.setState({
data: myData
})
})
.then( (json) => {
console.log('parsed json', json)
})
.catch( (ex) => {
console.log('parsing failed', ex)
})
console.log(this.state.data)
} // end componentDidMount
render() {
return (
<div className="App">
{this.state.data}
</div>
);
}
}
export default App;