为了账号安全,请及时绑定邮箱和手机立即绑定

js如何实现点击下载图片

标签:
JavaScript

通常我们知道一个文件的url,在前端我们可以通过代码:

window.open(url)

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

1. 方法一

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

<a href="https://geekjc-img.geekjc.com/logo.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" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="beauty.jpg"/>
    <a href="javascript:;" class="down_btn_a">点击下载</a></div><div class="card">    <img id="testimg" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="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" ="downloadImg();" width="0" height="0" class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="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. 备注



作者:极客教程
链接:https://www.jianshu.com/p/8ad12eb7e1f8


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消