I am just starting out with React and have already found myself in a loop. I am building an app that fetches data from a Flask API. Got everything set up so far, but I don't want to display all data on the first page. Rather, I want to split the data from the API and display it 10 at a time.
My problem is that I manage to split the data, but the DOM won't update on state change. Here is my code so far:
import React from 'react';
import Navbar from './Components/Navbar';
import Home from './Components/Home';
import {BrowserRouter as Router, Route, useHistory} from 'react-router-dom'
import Button from '@restart/ui/esm/Button';
class App extends React.Component {
constructor(props) {
super(props);
this.state = {
number: 10
}
}
updateContent = (prevState) => {
this.setState({number: this.state.number + 10});
}
render() {
return (
<Router>
<Navbar />
<Home perPage={this.state.number} />
<div class="text-center mt-3 mb-3">
{this.state.number}
<Button className='btn btn-primary' onClick={this.updateContent}>Mai multe intrebari</Button>
</div>
</Router>
);
}
}
export default App;
Even though number is update and I can display the updated {this.state.number}
in DOM (in same div
as Button
), changing it does not update my Home
component:
<Home perPage={this.state.number} />
where perPage
is a prop that I use to fetch data from my API:
useEffect(() => {
fetch("my_flask_api/v1/?id=" + props.perPage)
.then(res => res.json())
.then(
(result) => {
setIsLoaded(true);
setItems(result);
},
PS: It works if I manually change number
's value and it updates the DOM correctly, but it won't do it on setState()
.
Any ideas are welcome. Thanks in advance!
There are two things that you need to take care of:
this.setState(prevState => ({number: prevState.number + 10}))
; useEffect(() => {...}, [props.perPage])
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.