I’m trying to get a snapshot of HTML canvas like so:
JavaScript
x
4
1
const canvas = canvasRef.current
2
let image = canvas.toDataURL('image/jpeg');
3
await axios.post('/api/entries/', { dataURL: image })
4
which seems to be working, and connected properly to the database.
But I can’t figure out how to use the dataURL to create an image component on the React frontend
I’m able to fetch them from the backend just fine and log the dataURL.
JavaScript
1
3
1
const pics = await axios.get('/api/entries/')
2
pics.data.map((pic) => { console.log(pic.dataURL) })
3
I guess I’m just not sure of the next steps to get each dataURL into a element
Here is my getPics function:
JavaScript
1
10
10
1
const getPics = async () => {
2
const pics = await axios.get('/api/entries/')
3
4
return (
5
pics.data.map((pic) => (
6
<img src={pic.dataURL} key={pic.dataURL} />
7
))
8
)
9
}
10
and its used just like:
JavaScript
1
4
1
<div>
2
{getPics()}
3
</div>
4
Advertisement
Answer
Put the images into a state and put the fetch into a useEffect()
function.
JavaScript
1
10
10
1
const [pic,setPics] = useState();
2
3
useEffect(() => {
4
const getPics = async () => await axios.get('/api/entries/')
5
.then(res => {
6
setPics(res.data);
7
})
8
getPics();
9
}, [])
10
Mapping is the correct way to go… when mapping you can throw the data into a img element, this will render every image onto the page. the key value is for react to know the difference between each element.
JavaScript
1
6
1
return (
2
{pics.data.map((pic) => (
3
<img src={pic.dataURL} key={pic.dataURL} />
4
))}
5
)
6