Convert and Save Canvas Elements to Images in Browsers: A Quick Guide
Shivanshu Semwal
1 min read
Use developer tools to locate the canvas you want to download. Get it's id
attribute, in my case it was pdfCanvas
. Now enter this function in developer tools console:
function downloadCanvasAsImage(name){
// id of canvas element
let canvasId= 'pdfCanvas'
// get the canvas element, you have to change this with the element you want
let canvasImage = document.getElementById(canvasId).toDataURL('image/png');
let xhr = new XMLHttpRequest();
xhr.responseType = 'blob';
xhr.onload = function () {
let a = document.createElement('a');
a.href = window.URL.createObjectURL(xhr.response);
a.download = name + '.png';
a.style.display = 'none';
document.body.appendChild(a);
a.click();
a.remove();
};
xhr.open('GET', canvasImage);
xhr.send();
}
Now use this function to download the image,
let image_name = 'image.png'
downloadCanvasAsImage(image_name)
Here is how it works:
- first
canvasImage
should point to the canvas element in DOM, you can usegetElementById
orgetElementByTags
and then usetoDataURL
to get the URL to download image. - after that it sends a
XMLHttpsRequest
to get the images - the image is then downloaded with name passed as function parameter.
0
Subscribe to my newsletter
Read articles from Shivanshu Semwal directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
Shivanshu Semwal
Shivanshu Semwal
Software Developer. Interested in finding innovative solutions to problems.