Force the browser to download image files by click

I need the browser to download image files in the same way as when I click on an Excel sheet.

Is there a way to do this using only client-side programming?

<html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <script type="text/javascript" src="Scripts/jquery-1.10.2.js"> $(document).ready(function () { $("*").click(function () { $("p").hide(); }); }); </script> </head> <script type="text/javascript"> document.onclick = function (e) { e = e || window.event; var element = e.target || e.srcElement; if (element.innerHTML == "Image") { //someFunction(element.href); var name = element.nameProp; var address = element.href; saveImageAs1(element.nameProp, element.href); return false; // Prevent default action and stop event propagation } else return true; }; function saveImageAs1(name, adress) { if (confirm('you wanna save this image?')) { window.win = open(adress); //response.redirect("~/testpage.html"); setTimeout('win.document.execCommand("SaveAs")', 100); setTimeout('win.close()', 500); } } </script> <body> <form id="form1" runat="server"> <div> <p> <a href="http://localhost:55298/SaveImage/demo/Sample2.xlsx" target="_blank">Excel</a><br /> <a href="http://localhost:55298/SaveImage/demo/abc.jpg" id="abc">Image</a> </p> </div> </form> </body> </html> 

How should it work when loading an Excel worksheet (what browsers do)?

+78
javascript jquery html
Jul 08 '13 at 13:19
source share
13 answers

Using HTML5, you can add the download attribute to your links.

<a href="/path/to/image.png" download>

The respective browsers will then request to download the image with the same name (in this example, image.png).

If you specify a value for this attribute, this will become the new file name:

<a href="/path/to/image.png" download="AwesomeImage.png">

UPDATE: As of the spring of 2018, this is not possible for the cross origin of href s . Therefore, if you want to create <a href="https://i.imgur.com/IskAzqA.jpg" download> in a domain other than imgur.com, it will not work properly. Chrome opt-out and uninstall announcement

+143
Jul 08 '13 at 13:24
source share

I managed to get this working in Chrome and Firefox by adding a link to the document.

 var link = document.createElement('a'); link.href = 'images.jpg'; link.download = 'Download.jpg'; document.body.appendChild(link); link.click(); document.body.removeChild(link); 
+79
Jan 18 '14 at 22:16
source share

Leroy and Richard Parnaby King:

UPDATE: As of spring 2018, it is no longer possible for cross origin hrefs. Therefore, if you want to create in a domain other than imgur.com, it will not work properly. Chrome opt-out and uninstall announcement

 function forceDownload(url, fileName){ var xhr = new XMLHttpRequest(); xhr.open("GET", url, true); xhr.responseType = "blob"; xhr.onload = function(){ var urlCreator = window.URL || window.webkitURL; var imageUrl = urlCreator.createObjectURL(this.response); var tag = document.createElement('a'); tag.href = imageUrl; tag.download = fileName; document.body.appendChild(tag); tag.click(); document.body.removeChild(tag); } xhr.send(); } 
+22
Apr 17 '18 at 19:32
source share
 var pom = document.createElement('a'); pom.setAttribute('href', 'data:application/octet-stream,' + encodeURIComponent(text)); pom.setAttribute('download', filename); pom.style.display = 'none'; document.body.appendChild(pom); pom.click(); document.body.removeChild(pom); 
+12
Sep 09 '15 at 5:39
source share

Spring 2018 update

 <a href="/path/to/image.jpg" download="FileName.jpg"> 

Although this is still supported, as of February 2018, Chrome has disabled this feature for downloading from various sources, which means that it will only work if the file is on the same domain name.

I found a workaround for downloading cross-domain images after a new Chrome update that turned off cross-domain loading. You can change this into a function to suit your needs. You could get a MIME type image (JPEG, PNG, GIF, etc.) with some additional research if you need to. There may be a way to do something similar with the video as well. Hope this helps someone!

Lira and Richard Parnaby King:

UPDATE: Since the spring of 2018, this is no longer possible for cross-references. Therefore, if you want to create a domain other than imgur.com, it will not work as intended. Chrome Deprecation and Removal Announcement

 var image = new Image(); image.crossOrigin = "anonymous"; image.src = "https://is3-ssl.mzstatic.com/image/thumb/Music62/v4/4b/f6/a2/4bf6a267-5a59-be4f-6947-d803849c6a7d/source/200x200bb.jpg"; // get file name - you might need to modify this if your image url doesn't contain a file extension otherwise you can set the file name manually var fileName = image.src.split(/(\\|\/)/g).pop(); image.onload = function () { var canvas = document.createElement('canvas'); canvas.width = this.naturalWidth; // or 'width' if you want a special/scaled size canvas.height = this.naturalHeight; // or 'height' if you want a special/scaled size canvas.getContext('2d').drawImage(this, 0, 0); var blob; // ... get as Data URI if (image.src.indexOf(".jpg") > -1) { blob = canvas.toDataURL("image/jpeg"); } else if (image.src.indexOf(".png") > -1) { blob = canvas.toDataURL("image/png"); } else if (image.src.indexOf(".gif") > -1) { blob = canvas.toDataURL("image/gif"); } else { blob = canvas.toDataURL("image/png"); } $("body").html("<b>Click image to download.</b><br><a download='" + fileName + "' href='" + blob + "'><img src='" + blob + "'/></a>"); }; 
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
+10
Apr 14 '18 at 21:57
source share

This is a general solution to your problem. But there is one very important part that the file extension must match your encoding. And, of course, this parameter of the content of the downlowadImage function should be a base64 encoded line of your image.

 const clearUrl = url => url.replace(/^data:image\/\w+;base64,/, ''); const downloadImage = (name, content, type) => { var link = document.createElement('a'); link.style = 'position: fixed; left -10000px;'; link.href = `data:application/octet-stream;base64,${encodeURIComponent(content)}`; link.download = /\.\w+/.test(name) ? name : `${name}.${type}`; document.body.appendChild(link); link.click(); document.body.removeChild(link); } ['png', 'jpg', 'gif'].forEach(type => { var download = document.querySelector(`#${type}`); download.addEventListener('click', function() { var img = document.querySelector('#img'); downloadImage('myImage', clearUrl(img.src), type); }); }); 
 a gif image: <image id="img" src="" /> <button id="png">Download PNG</button> <button id="jpg">Download JPG</button> <button id="gif">Download GIF</button> / 95eX5NWvsJCOVNQPtfX / 8zM8 + QePLl38MGBr8JCP + zs9myn / 8GBqwpAP / GxgwJCPny78lzYLgjAJ8vAP9fX / + MjMUcAN8zM / 9wcM8ZGcATEL + QePdZWf / 29uc / P9cmJu9MTDImIN + / r7 + / vz8 / P8VNQGNugV8AAF9fX8swMNgTAFlDOICAgPNSUnNWSMQ5MBAQEJE3QPIGAM9AQMqGcG9vb6MhJsEdGM8vLx8fH98AANIWAMuQeL8fABkTEPPQ0OM5OSYdGFl5jo + Pj / + pqcsTE78wMFNGQLYmID4dGPvd3UBAQJmTkP + 8vH9QUK + vr8ZWSHpzcJMmILdwcLOGcHRQUHxwcK9PT9DQ0O / v70w5MLypoG8wKOuwsP a gif image: <image id="img" src="" /> <button id="png">Download PNG</button> <button id="jpg">Download JPG</button> <button id="gif">Download GIF</button> / f39Wsl + LFt8dgUE9PT5x5aHBwcP + AgP + WltdgYMyZfyywz78AAAAAAAD /// 8AAP9mZv /// wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA a gif image: <image id="img" src="" /> <button id="png">Download PNG</button> <button id="jpg">Download JPG</button> <button id="gif">Download GIF</button> + fOqD6DDj1aZpITp0dtGCDhr + fVuCu3zlg49ijaokTZTo27uG7Gjn2P + hI8 + PDPERoUB318bWbfAJ5sUNFcuGRTYUqV / 3ogfXp1rWlMc6awJjiAAd2fm4ogXjz56aypOoIde4OE5u / F9x199dlXnnGiHZWEYbGpsAEA3QXYnHwEFliKAgswgJ8LPeiUXGwedCAKABACCN + EA1pYIIYaFlcDhytd51sGAJbo3onOpajiihlO92KHGaUXGwWjUBChjSPiWJuOO / LYIm4v1tXfE6J4gCSJEZ7YgRYUNrkji9P55sF / ogxw5ZkSqIDaZBV6aSGYq / lGZplndkckZ98xoICbTcIJGQAZcNmdmUc210hs35nCyJ58fgmIKX5RQGOZowxaZwYA + JaoKQwswGijBV4C6SiTUmpphMspJx9unX4KaimjDv9aaXOEBteBqmuuxgEHoLX6Kqx + yXqqBANsgCtit4FWQAEkrNbpq7HSOmtwag5w57GrmlJBASEU18ADjUYb3ADTinIttsgSB1oJFfA63bduimuqKB1keqwUhoCSK374wbujvOSu4QG6UvxBRydcpKsav ++ Ca6G8A6Pr1x2kVMyHwsVxUALDq / krnrhPSOzXG1lU a gif image: <image id="img" src="" /> <button id="png">Download PNG</button> <button id="jpg">Download JPG</button> <button id="gif">Download GIF</button> PJHgxw0xH74yx / 3XnaYRJgMB8obxQW6kL9QYEJ0FIFgByfIL7 / IQAlvQwEpnAC7DtLNJCKUoO / w45c44GwCXiAFB / OXAATQryUxdN4LfFiwgjCNYg + kYMIEFkCKDs6PKAIJouyGWMS1FSKJOMRB / BoIxYJIUXFUxNwoIkEKPAgCBZSQHQ1A2EWDfDEUVLyADj5AChSIQW6gu10bE / JG2VnCZGfo4R4d0sdQoBAHhPjhIB94v / wRoRKQWGRHgrhGSQJxCS + 0pCZbEhAAOw == "/> a gif image: <image id="img" src="" /> <button id="png">Download PNG</button> <button id="jpg">Download JPG</button> <button id="gif">Download GIF</button> 
+5
Oct 13 '15 at 20:10
source share

Try the following:

 <a class="button" href="http://www.glamquotes.com/wp-content/uploads/2011/11/smile.jpg" download="smile.jpg">Download image</a> 
+1
Nov 21 '16 at 12:01
source share

You can directly download this file using the anchor tag without much code.
Copy the fragment and paste it into a text editor and try ...!

 <html> <head> </head> <body> <div> <img src="https://upload.wikimedia.org/wikipedia/commons/1/1f/SMirC-thumbsup.svg" width="200" height="200"> <a href="#" download="https://upload.wikimedia.org/wikipedia/commons/1/1f/SMirC-thumbsup.svg"> Download Image </a> </div> </body> </html> 
+1
Mar 08 '19 at 10:50
source share

A more modern approach using Promise and async / await:

 toDataURL(url) { return fetch(url).then((response) => { return response.blob(); }).then(blob => { return URL.createObjectURL(blob); }); } 

then

 async download() { const a = document.createElement("a"); a.href = await toDataURL("https://cdn1.iconfinder.com/data/icons/ninja-things-1/1772/ninja-simple-512.png"); a.download = "myImage.png"; document.body.appendChild(a); a.click(); document.body.removeChild(a); } 

Find documentation here: https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch

+1
May 08 '19 at 13:23
source share

What about using the .click () function and tag?

(Compressed version)

 <a id="downloadtag" href="examplefolder/testfile.txt" hidden download></a> <button onclick="document.getElementById('downloadtag').click()">Download</button> 

Now you can run it using JS. It also does not open, like other examples, graphic and text files!

(js function version)

 function download(){ document.getElementById('downloadtag').click(); } 
 <!-- HTML --> <button onclick="download()">Download</button> <a id="downloadtag" href="coolimages/awsome.png" hidden download></a> 
0
Jun 19 '19 at 12:53 on
source share
 <html> <head> <script type="text/javascript"> function prepHref(linkElement) { var myDiv = document.getElementById('Div_contain_image'); var myImage = myDiv.children[0]; linkElement.href = myImage.src; } </script> </head> <body> <div id="Div_contain_image"><img src="YourImage.jpg" alt='MyImage'></div> <a href="#" onclick="prepHref(this)" download>Click here to download image</a> </body> </html> 
-one
May 13 '15 at 5:51
source share

I found that

<a href="link/to/My_Image_File.jpeg" download>Download Image File</a>

didn't work for me. I'm not sure why.

I found that you can enable the ?download=true Download ?download=true option at the end of your link to force download. I think I noticed that this method is used by Google Drive.

In your link, include ?download=true at the end of your href.

You can also use this technique to set the file name at the same time.

In your link, include ?download=true&filename=My_Image_File.jpeg at the end of your href.

-5
Aug 04 '15 at 23:42 on
source share

You do not need to write js for this, just use:

 <a href="path_to/image.jpg" alt="something">Download image</a> 

And the browser itself will automatically download the image.

If for some reason it does not work, add a download attribute. With this attribute you can set a name for the uploaded file:

 <a href="path_to/image.jpg" download="myImage">Download image</a> 
-fifteen
Jul 08 '13 at 13:32
source share



All Articles