ajax 实现文件下载功能

ajax一般是用来请求服务端的数据,下载文件需要先从服务器获取文件请求路径,然后使用form表单提交的方法来实现文件的下载。

先引入jquery文件,jquery的免费cdn地址:<script src="https://cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>
// 定义到jQuery全局变量下-文件下载
jQuery.download = function (url, method, filedir) {
  jQuery('<form action="' + url + '" method="' + (method || 'post') + '">' +  // action请求路径及推送方法
              '<input type="text" name="filePath" value="' + filedir + '"/>' + // 文件路径
          '</form>')
  .appendTo('body').submit().remove();
  //var newTab = window.open('about:blank')
  //newTab.location.href = url;
};
使用:

//导出事件
            $('#btnExport').click(function (e) {
                e.preventDefault();//阻止a链接的跳转行为
                $.ajax({
                    type: "post",
                    url: "/FileExport/Export",
                    dataType: "json",
                    data: { address: addr},
                    success: function (data) {
                        $.download('/FileExport/DownLoadFile', 'post', data.value); // 下载文件
                    },
                    error: function (data) {
                        alert("对不起,出现错误,请稍后重试或联系管理员");
                    }
                });
            });



  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值