强制浏览器在点击时下载图像文件

Ami*_*mit 89 html javascript jquery

我需要浏览器下载图像文件,就像点击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>
Run Code Online (Sandbox Code Playgroud)

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

Ric*_*ing 154

使用HTML5,您可以将属性"download"添加到链接中.

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

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

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

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

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

  • 尚未完全支持所有浏览器,但如果您不关心IE或Safari,这是一个很好的解决方案.http://caniuse.com/#feat=download (2认同)

小智 88

通过添加指向文档的链接,我设法在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);
Run Code Online (Sandbox Code Playgroud)

  • 好的解决方案,谢谢!请注意,如果省略`document.body.appendChild(link)`,它将无法在Firefox中运行.使用`document.body.removeChild(link);``link.click()之后删除创建的元素也是一件好事. (13认同)
  • 最佳方案.为了避免DOM中的垃圾,请使用`setTimeout(function(){link.parentNode.removeChild(link);},10);` (8认同)
  • 对于网络应用来说,这实际上是一个非常好的解决方案,其中Javascript就在附近.但是,仅适用于Google Chrome(在我的测试设置中). (2认同)
  • NB1:由于 CORS,这在本地不起作用。NB2:在 macOS Brave 中,这会立即保存图像。在 iOS Safari 中,这会生成一个对话框,询问您是否要查看或保存图像。如果你保存,它会进入一个只能在 iOS Safari 中访问的神秘地方(我希望它保存到我的图像应用程序中,详细信息请参见 https://macreports.com/how-to-manage-safari-downloads-on-iphone-和-ipad/)。在 iOS Brave 上,它只是打开图像。 (2认同)

Cur*_*rse 30

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

toDataURL(url) {
    return fetch(url).then((response) => {
            return response.blob();
        }).then(blob => {
            return URL.createObjectURL(blob);
        });
}
Run Code Online (Sandbox Code Playgroud)

然后

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);
}
Run Code Online (Sandbox Code Playgroud)

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

  • 如果请求的图像被 CORS 策略阻止,这将不起作用。 (3认同)

iXs*_*iXs 26

Leeroy&Richard Parnaby-King:

更新:从2018年春季开始,对于跨源hrefs不再可能.因此,如果您想在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();
}
Run Code Online (Sandbox Code Playgroud)

  • 图像下载但未打开,因为它声明“图像已损坏” (2认同)

Ril*_*ell 13

更新2018年春季

<a href="/path/to/image.jpg" download="FileName.jpg">
Run Code Online (Sandbox Code Playgroud)

虽然仍支持此功能,但从2018年2月开始,Chrome禁用了此功能的跨域下载功能,这意味着仅在文件位于相同域名时才有效。

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

Leeroy和Richard Parnaby-King:

更新:从2018年春季开始,跨域href不再可行。因此,如果要在imgur.com以外的域上创建,它将无法正常工作。Chrome版本弃用和移除公告

<a href="/path/to/image.jpg" download="FileName.jpg">
Run Code Online (Sandbox Code Playgroud)
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>");
};
Run Code Online (Sandbox Code Playgroud)


小智 11

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);     
Run Code Online (Sandbox Code Playgroud)

  • safari浏览器不支持下载属性 (4认同)

Vla*_*ero 11

创建一个记录图像 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'));
}
Run Code Online (Sandbox Code Playgroud)
<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>
Run Code Online (Sandbox Code Playgroud)

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

弗拉迪.cc


hak*_*ogh 8

这是您的问题的一般解决方案.但是有一个非常重要的部分,文件扩展名应该与您的编码匹配.当然,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);
  });
});
Run Code Online (Sandbox Code Playgroud)
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>
Run Code Online (Sandbox Code Playgroud)

  • 请在答案中添加简短说明,以使其与提出问题的人员相关 (3认同)

vin*_*nod 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>
Run Code Online (Sandbox Code Playgroud)

  • 我厌倦了它,并且不适合我。我无法理解它应该如何,因为“download”属性用于给出[元素的标题](https://www.w3schools.com/tags/att_a_download.asp)而不是路径 (4认同)
  • 请添加更多详细信息,例如可以使用此代码的位置。 (3认同)
  • 这会为我下载某种 html 内容 (2认同)

Pet*_*sky 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);
Run Code Online (Sandbox Code Playgroud)