I want to update my state in foreach but when I check, It just keeps the last one and it doesn't keep previous data.
import './App.css';
import Card from "./Card"
import Books from "./Books"
import { useEffect, useState } from 'react';
import axios from "axios"
import BooksInfo from './Books';
function App() {
const [bookInfo,setBookInfo] = useState([])
useEffect( ()=>{
let bname = ""
let bauthor = ""
let bcover = 0
async function getInfo(){
let results = Promise.all(BooksInfo.map(book=>{
let result = axios.get(`https://openlibrary.org/search.json?q=${book}`)
return result
}))
;(await results).forEach(result=>{
console.log(result)
bname= result.data.docs[0].title_suggest
bauthor= result.data.docs[0].author_name[0]
bcover= result.data.docs[0].cover_i
setBookInfo([...bookInfo , { name:bname , author:bauthor , cover:bcover }]);
console.log(bookInfo)
})
}
getInfo()
},[])