文件下载前端js三种方式

背景介绍

在公司开发业务经常会用到,文件下载相关功能,产品要去的形式不同:点击链接就可以下载、form提交下载、伪提交form下载。
下面就三种方式逐一介绍。

伪form提交下载

先上代码:

function downloadFile(url, data, method) {
    var form = document.createElement('form');
    form.setAttribute('style','display:none');
    form.setAttribute('target','');
    form.setAttribute('method','post');
    form.setAttribute('action',url)
    $('body').append(form);
        jQuery.each(data.split('&'), function () {
            var pair = this.split('=');
            var inputContent = document.createElement('input');
            inputContent.setAttribute('type','hidden');
            inputContent.setAttribute('name',pair[0]);
            inputContent.setAttribute('value',pair[1]);
            form.append(inputContent);
        });

    form.submit();
    form.remove();
}

整体的思路就是通过按钮点击事件隐性的建立一个表单,给表单赋值元素的值(input框),和属性值(method,url等),提交给后台进行文件下载。

form表单提价下载

顾名思义就是通过form表单的action,submit之后进行传输到后台下载的方式,代码走起:


链接下载的方式

这种方式一般在列表,或者有明确下载文件的时候(比如模板)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值