全部
常见问题
产品动态
精选推荐

文件下载功能实例代码

管理 管理 编辑 删除

一般来说前端实现的思路就是通过动态创建a标签,设置其download属性,最后删除a就好了,对于不是图片的文件一般都可以下载,但是如果是图片,有些浏览器会自动打开图片,所以我们需要手动把它转化为data:URLs或blob:URLs,基于这个原理,我们可以用fileReader,也可以用fetch-URL.createObjectURL,这里经过大量测试我采用后

<a href="/static/xxxxx.csv" download="fileName">绝对路径写法

2.配合后端来写原理简单就是后端返回  url   download写上文件名

filename  

直接a标签下载就行了

function
download(url, filename) {
eturn fetch(url).then(res => res.blob().then(blob => {
        //创建a标签
        let a = document.createElement('a');
        //处理后端url
        let url = window.URL.createObjectURL(blob);
        //给a标签赋值
        a.href = url;
        a.download = filename;
        a.click();    
        // 释放blob对象
        window.URL.revokeObjectURL(url);
    }))
}
自己写的代码,页面写一个点击事件,拿到相对应的值就可以了
//html页面
   <template slot-scope="datarow">
            <el-button type="text" @click="downloadExcel(datarow.row.url,datarow.row.fileName)">下载</el-button>
          </template>
 
 // 下载文件
    downloadExcel(url, fileName) {
      // console.log(url,fileName,)
      let param = {
        fileName: fileName
      };
      apiDownLoad(url, param).then(res => {
        var blob = new Blob([res], { type: "application/octet-stream" });
        if (window.navigator.msSaveOrOpenBlob) {
          //msSaveOrOpenBlob方法返回bool值
          navigator.msSaveBlob(blob, fileName); //本地保存
        } else {
          var link = document.createElement("a"); //a标签下载
          link.href = window.URL.createObjectURL(blob);
          link.download = fileName;
          link.click();
          window.URL.revokeObjectURL(link.href);
        }
      });
    },

902b2202303021813201564.png

请登录后查看

CRMEB-慕白寒窗雪 最后编辑于2023-03-02 18:14:46

快捷回复
回复({{post_count}}) {{!is_user ? '我的回复' :'全部回复'}}
排序 默认正序 回复倒序 点赞倒序

{{item.user_info.nickname ? item.user_info.nickname : item.user_name}}

作者 管理员 企业

{{item.floor}}# 同步到gitee 已同步到gitee {{item.is_suggest==1? '取消推荐': '推荐'}}
沙发 板凳 地板 {{item.floor}}#
{{item.user_info.title}}
附件

{{itemf.name}}

{{item.created_at}}  {{item.ip_address}}
{{item.like_count}}
{{item.showReply ? '取消回复' : '回复'}}
删除
回复
回复

{{itemc.user_info.nickname}}

{{itemc.user_name}}

作者 管理员 企业

回复 {{itemc.comment_user_info.nickname}}

附件

{{itemf.name}}

{{itemc.created_at}}   {{itemc.ip_address}}
{{itemc.like_count}}
{{itemc.showReply ? '取消回复' : '回复'}}
删除
回复
回复
查看更多
回复
回复
2420
{{like_count}}
{{collect_count}}
添加回复 ({{post_count}})

相关推荐

快速安全登录

使用微信扫码登录
{{item.label}} {{item.label}} {{item.label}} 板块推荐 常见问题 产品动态 精选推荐 首页头条 首页动态 首页推荐
加精
取 消 确 定
回复
回复
问题:
问题自动获取的帖子内容,不准确时需要手动修改. [获取答案]
答案:
提交
bug 需求 取 消 确 定

微信登录/注册

切换手机号登录

{{ bind_phone ? '绑定手机' : '手机登录'}}

{{codeText}}
切换微信登录/注册
暂不绑定
CRMEB客服

CRMEB咨询热线 咨询热线

400-8888-794

微信扫码咨询

CRMEB开源商城下载 源码下载 CRMEB帮助文档 帮助文档
返回顶部 返回顶部
CRMEB客服