For some reason when I am updating my state from the useEffect hook it is not persisting. I am expecting that my list of users will keep growing, but instead I am only seeing one user. Why is users not growing?
import { useState, useEffect } from "react";
interface IUser {
name: {
first: string;
last: string;
};
picture: {
thumbnail: string;
};
}
function App() {
const [users, setUsers] = useState<IUser[]>([]);
const getUserName = (user: IUser): string => {
if (!user) return "";
return `${user.name.first} ${user.name.last}`;
};
const getThumbnail = (user: IUser): string => {
if (!user) return "";
return user.picture.thumbnail;
};
useEffect(() => {
setInterval(() => {
fetch("https://randomuser.me/api")
.then((res) => res.json())
.then((json) => {
let newusers = [...users, json.results[0]];
setUsers(newusers);
})
.catch((err) => {
console.log(err);
});
}, 3000);
}, []);
return (
<div className="App">
{users?.map((user, idx) => (
<div key={idx}>
<h2>{getUserName(user)}</h2>
<img src={getThumbnail(user)} />
</div>
))}
</div>
);
}
export default App;
Here is a codesandbox demonstrating the issue https://codesandbox.io/s/react-typescript-forked-5h3553?file=/src/App.tsx:0-1054