js如何实现点击下载图片

作者 : 开心源码 本文共2597个字,预计阅读时间需要7分钟 发布时间: 2022-05-11 共100人阅读

通常我们知道一个文件的url,在前台我们能通过代码:

window.open(url)

实现下载文件的功可以,但是如何是图片url的话,会新开一个页面,并不会将图片下载,那怎样实现将图片下载下来呢?

1. 方法一

<a>标签.html5的a标签添加了download属性,可利使用此属性实现图片下载.

<a href="https://alpic.fanquanwang.com/kx3x/uppic/logo4952.png" download="logo.png">下载图片</a>
  1. 将a标签的href属性指向图片的地址;同时添加download属性;就可实现点击下载.
  2. download属性的属性值选填,代表下载图片的名称,如不填写,则用href中的图片名称,即图片的原名称.
  3. a标签的download属性目前主流浏览器只有火狐和谷歌支持.

由于上诉方法只有火狐和谷歌支持,所以我们还要兼容其它浏览器

2. 方法二

<iframe>标签.生成iframe,src指向图片地址,调使用document.execCommand(“SaveAs”)方法.
所以在Trident内核浏览器(IE等)下,给按钮(a标签)绑定事件,用创立<iframe>标签方法;

在火狐,谷歌下用<a>标签的download属性进行下载.

首先判断浏览器,决定添加属性,还是绑定事件;

在绑定事件的逻辑内,

首先判断页面能否存在指定的<iframe>,不存在则生成,存在则修改src属性.

而后调使用SaveAs命令进行保存.

下面举个简单的栗子.在图片列表中,给每个图片添加一个下载功可以按钮.

  1. html代码
<div class="card">    <img id="testimg" src="beauty.jpg"/>    <a href="javascript:;" class="down_btn_a">点击下载</a></div><div class="card">    <img id="testimg" src="timg.jpg"/>    <a href="javascript:;" class="down_btn_a">点击下载</a></div>
  1. css代码
*{    padding: 0;    margin: 0;}img {    display: block;    width: 500px;}.card{    display: inline-block;    position: relative;    width: 400px;    height: 250px;}.card img{    width: 100%;}.card .down_btn_a {    display: inline-block;    position: absolute;    right: 0;    bottom: 0;    width: 100px;    height: 40px;    line-height: 40px;    background-color: #20b1aa;    text-decoration: none;    text-align: center;    color: #fff;}.card .down_btn_a:hover {    background-color: #ccc;    color: #000;}
  1. js功可以实现代码
//判断能否为Trident内核浏览器(IE等)函数function browserIsIe() {    if (!!window.ActiveXObject || "ActiveXObject" in window){        return true;    }    else{        return false;    }}//创立iframe并赋值的函数,传入参数为图片的src属性值.function createIframe(imgSrc) {    //假如隐藏的iframe不存在则创立    if ($("#IframeReportImg").length === 0){        $('<iframe style="display:none;" id="IframeReportImg" name="IframeReportImg" onload="downloadImg();" width="0" height="0" src="about:blank"></iframe>').appendTo("body");    }    //iframe的src属性如不指向图片地址,则手动修改,加载图片    if ($('#IframeReportImg').attr("src") != imgSrc) {        $('#IframeReportImg').attr("src",imgSrc);    } else {        //如指向图片地址,直接调使用下载方法        downloadImg();    }}//下载图片的函数function downloadImg() {    //iframe的src属性不为空,调使用execCommand(),保存图片    if ($('#IframeReportImg').src != "about:blank") {        window.frames["IframeReportImg"].document.execCommand("SaveAs");    }}//接下来进行事件绑定var aBtn = $(".card .down_btn_a");if (browserIsIe()) {    //是ie等,绑定事件    aBtn.on("click", function() {        var imgSrc = $(this).siblings("img").attr("src");        //调使用创立iframe的函数        createIframe(imgSrc);    });} else {    aBtn.each(function(i,v){    //支持download,增加属性.    var imgSrc = $(v).siblings("img").attr("src");    $(v).attr("download",imgSrc);    $(v).attr("href",imgSrc);    })}

3. 备注

  • 支持 谷歌 火狐 IE8及以上 360极速浏览器 QQ浏览器其余浏览器未测试,安卓手机测试Android5.0成功

  • 本人测试的代码 Sun-Y0n9/download-image

  • Javascript中document.execCommand()的使用法参考CSDN的文章

    • .http://blog.csdn.net/woshinia/article/details/18664903
  • 因为IE上涉及iframe的加载,所以要本地起一个服务来测试,起服务方式请点击.

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » js如何实现点击下载图片

发表回复