js或者vue中怎么点击下载图片(图片是第三方的url)?

如题:
需求是pc后台中,点击按钮下载对应的图片保存到本地,因为图片地址是第三方的url,如果使用标签会造成是打开新页面显示,而不是下载保存到本地,请问有没有其他办法?

附:
图片地址

http://qr.topscan.com/api.php?text=https://code.dddiancan.com/kc_code?tableId=24&storeId=4&appVersion=2
阅读 8.6k
2 个回答

1.可以用a标签download属性

<a href="https://geekjc-img.geekjc.com/logo.png" download="logo.png">下载图片</a>

只兼容谷歌和火狐浏览器

2.<iframe>标签.生成iframe,src指向图片地址,调用document.execCommand("SaveAs")方法,基本全兼容
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>

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

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

支持 谷歌 火狐 IE8及以上

npm install file-saver --save
可以用这个库试试

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题