126

我需要浏览器下载图像文件,就像单击 Excel 工作表一样。

有没有办法只使用客户端编程来做到这一点?

<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>

如果下载 Excel 表格(浏览器做什么),它应该如何工作?

4

15 回答 15

195

使用 HTML5,您可以将属性“下载”添加到您的链接。

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

兼容的浏览器将提示下载具有相同文件名的图像(在此示例中为 image.png)。

如果您为此属性指定一个值,那么它将成为新的文件名:

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

更新:从 2018 年春季开始,跨域hrefs不再可能。因此,如果您想<a href="https://i.imgur.com/IskAzqA.jpg" download>在 imgur.com 以外的域上创建,它将无法按预期工作。Chrome 弃用和删除公告

于 2013-07-08T13:24:18.053 回答
123

通过将链接附加到文档,我也设法使其在 Chrome 和 Firefox 中工作。

var link = document.createElement('a');
link.href = 'images.jpg';
link.download = 'Download.jpg';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
于 2014-01-18T22:16:58.617 回答
50

Leeroy 和 Richard Parnaby-King:

更新:从 2018 年春季开始,跨域 href 不再可能。因此,如果您想在 imgur.com 以外的域上创建,它将无法按预期工作。Chrome 弃用和删除公告

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();
}
于 2018-04-17T19:32:11.740 回答
37

使用 Promise 和 async/await 的更现代的方法:

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

然后

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);
}

在此处查找文档:https ://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch

于 2019-05-08T13:23:46.120 回答
22

2018 年春季更新

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

虽然这仍然受支持,但截至 2018 年 2 月,chrome 禁用了此功能以进行跨域下载,这意味着这仅在文件位于同一域名上时才有效。

在 Chrome 的新更新禁用跨域下载之后,我想出了一个下载跨域图像的解决方法。您可以将其修改为适合您需要的函数。如果需要,您可以通过更多研究获得图像 mime 类型(jpeg、png、gif 等)。也可能有一种方法可以对视频执行类似的操作。希望这对某人有帮助!

Leeroy 和 Richard Parnaby-King:

更新:从 2018 年春季开始,跨域 href 不再可能。因此,如果您想在 imgur.com 以外的域上创建,它将无法按预期工作。Chrome 弃用和删除公告

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>

于 2018-04-14T21:57:21.020 回答
14
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);     
于 2015-09-09T05:39:19.390 回答
11

这是您问题的一般解决方案。但是有一个非常重要的部分是文件扩展名应该与您的编码匹配。当然,downlowadImage 函数的内容参数应该是图像的 base64 编码字符串。

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>

于 2015-10-13T20:10:40.427 回答
7

创建一个功能,recibe 图像 url 和文件名并使用按钮调用该功能。

function downloadImage(url, name){
      fetch(url)
        .then(resp => resp.blob())
        .then(blob => {
            const url = window.URL.createObjectURL(blob);
            const a = document.createElement('a');
            a.style.display = 'none';
            a.href = url;
            // the filename you want
            a.download = name;
            document.body.appendChild(a);
            a.click();
            window.URL.revokeObjectURL(url);
        })
        .catch(() => alert('An error sorry'));
}
<button onclick="downloadImage('https://upload.wikimedia.org/wikipedia/commons/thumb/0/02/Stack_Overflow_logo.svg/1280px-Stack_Overflow_logo.svg.png', 'LogoStackOverflow.png')" >DOWNLOAD</button>

Codepen.io 使用 JavaScript 强制下载图片

vladi.codes

于 2021-08-10T07:10:18.377 回答
6

您可以使用锚标记直接下载此文件,无需太多代码。
复制片段并粘贴到您的文本编辑器中,然后尝试...!

<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>

于 2019-03-08T10:50:40.403 回答
5

在 2020 年,我使用Blob制作图像的本地副本,浏览器将下载该图像作为文件。您可以在此站点上对其进行测试。

在此处输入图像描述

(function(global) {
  const next = () => document.querySelector('.search-pagination__button-text').click();
  const uuid = () => Math.random().toString(36).substring(7);
  const toBlob = (src) => new Promise((res) => {
    const img = document.createElement('img');
    const c = document.createElement("canvas");
    const ctx = c.getContext("2d");
    img.onload = ({target}) => {
      c.width = target.naturalWidth;
      c.height = target.naturalHeight;
      ctx.drawImage(target, 0, 0);
      c.toBlob((b) => res(b), "image/jpeg", 0.75);
    };
    img.crossOrigin = "";
    img.src = src;
  });
  const save = (blob, name = 'image.png') => {
    const a = document.createElement("a");
    a.href = URL.createObjectURL(blob);
    a.target = '_blank';
    a.download = name;
    a.click();
  };
  global.download = () => document.querySelectorAll('.search-content__gallery-results figure > img[src]').forEach(async ({src}) => save(await toBlob(src), `${uuid()}.png`));
  global.next = () => next();
})(window);
于 2020-06-13T12:19:10.997 回答
2

尝试这个:

<a class="button" href="http://www.glamquotes.com/wp-content/uploads/2011/11/smile.jpg" download="smile.jpg">Download image</a>
于 2016-11-21T12:01:39.390 回答
0
<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>
于 2015-05-13T05:51:19.727 回答
-5

我找到

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

对我不起作用。我不确定为什么。

我发现您可以?download=true在链接末尾包含一个参数来强制下载。我想我注意到 Google Drive 正在使用这种技术。

在您的链接中,包括?download=true在您的 href 末尾。

您还可以使用此技术同时设置文件名。

在您的链接中,包括?download=true&filename=My_Image_File.jpeg在您的 href 末尾。

于 2015-08-04T23:42:08.847 回答
-6

使用 .click() 函数和标签怎么样?

(压缩版)

<a id="downloadtag" href="examplefolder/testfile.txt" hidden download></a>

<button onclick="document.getElementById('downloadtag').click()">Download</button>

现在可以用js触发了。与其他示例一样,它也无法打开图像和文本文件!

(js函数版)

function download(){
document.getElementById('downloadtag').click();
}
<!-- HTML -->
<button onclick="download()">Download</button>
<a id="downloadtag" href="coolimages/awsome.png" hidden download></a>

于 2019-06-19T12:53:43.890 回答
-17

你不需要编写js来做到这一点,只需使用:

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

并且浏览器本身会自动下载图像。

如果由于某种原因它不起作用,请添加下载属性。使用此属性,您可以为可下载文件设置名称:

<a href="path_to/image.jpg" download="myImage">Download image</a>
于 2013-07-08T13:32:11.640 回答