文件导出下载到本地

这篇博客介绍了如何在前端实现文件下载功能,包括通过axios处理错误并触发下载,以及使用Blob对象导出Excel文件。示例代码展示了downloadFile函数如何调用API获取文件,以及如何处理错误以直接触发zip文件的下载。此外,还提供了exprotExcal函数用于生成Excel文件,该函数接收文件名和二进制数据,创建Blob对象并触发浏览器下载。
摘要由CSDN通过智能技术生成

 1:

export async function downloadFile(exportRecordId) {
    try {
        let result = await exportApi.getDownloadFile({ exportRecordId });
        return result;
    } catch (error) {
        // axios错误处理,页面走catch
        if (error.response) {
            return Promise.reject(error.response);
        }
        if (error.type === "application/zip") {
            const a = document.createElement("a");
            const href = window.URL.createObjectURL(error);
            a.href = href;
            a.download = `xxx.zip`;
            document.body.appendChild(a);
            a.click();
            document.body.removeChild(a); // 下载完成移除元素
            window.URL.revokeObjectURL(href);
            return { code: 200, data: null };
        } else {
            let data = await error.text();
            return JSON.parse(data);
        }
    }
}

2:

拦截器:

    putFile: (url) => {
        return instance.get(url, { responseType: "blob" });
    },
/**
 * 导出Excel
 * @param name 文件名
 * @param data 二进制流
 */
export const exprotExcal = (name, data) => {
    const Link = new Blob([data], {
        type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8",
    });
    const fileName = name + ".xlsx";
    const a = document.createElement("a");
    a.download = fileName;
    a.href = URL.createObjectURL(Link);
    document.body.appendChild(a);
    a.click();
    URL.revokeObjectURL(a.href);
    document.body.removeChild(a);
};

转载  参考  http://t.csdn.cn/AqRiC

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值