【发布时间】:2026-01-05 13:50:02
【问题描述】:
所以,我只是想在我的 react 应用中设置状态。只需从 Axios 获取数据,然后设置状态。但是无论我做什么,状态都不会设置。我已经尝试将它放在回调中,因为它是异步的,并且我的组件确实挂载了它,并且组件确实没有更新。有什么指点吗?
class App extends Component {
componentDidUpdate() {}
constructor(props) {
super(props);
this.state = {
Catogories: [
"Business",
"Entertainment",
"General",
"Health",
"Science",
"Sports",
"Technology"
],
CatPics: [],
TopStories: [],
Selection: [],
Sources: [],
selected: false
};
}
GeneratePic = () => {
this.state.Catogories.forEach(Catogory => {
axios
.get(
"https://api.pexels.com/v1/search?query=" +
Catogory +
"&per_page=15&page=1",
{
Authorization:
"563492ad6f91700001000001d33b5d31a9a145b78ee67e35c8e6c321"
}
)
.then(res => {
var object = { Catogory: res.photos[0].src.large2x };
this.state.CatPics.push(object);
});
});
};
dump = x => {
this.setState({ TopStories: x }, console.log(this.state.TopStories));
};
TopStories = () => {
console.log("working");
axios
.get(
"https://newsapi.org/v2/top-headlines?country=us&apiKey=91bec895cf8d45eaa46124fb19f6ad81"
)
.then(res => {
console.log(res);
const data = res.data.articles;
console.log(data);
this.dump(data);
});
};
【问题讨论】:
-
this.state.CatPics.push改变状态。请改用this.setState函数,并始终避免改变当前(或更旧的)状态对象。 -
另外,
setStatesecond argument should be a function 但您只是直接输入了console.log,这不会像您认为的那样。
标签: javascript reactjs axios es6-promise