js 将json数据转成excel导出

1、安装XLSX库。
2、直接引入XLSX库。
3、将json数据导出excel

import moment from 'moment';
export const downloadExl = (json, type = 'xlsx', saveAs) => {
    //这里的数据是用来定义导出的格式类型
    const wopts = {
        bookType: type,
        bookSST: false,
        type: 'binary'
    };
    const wb = {
        SheetNames: ['Sheet1'],
        Sheets: {},
        Props: {}
    };
    wb.Sheets['Sheet1'] = XLSX.utils.json_to_sheet(json); //通过json_to_sheet转成单页(Sheet)数据
    let tmpDown = new Blob([s2ab(XLSX.write(wb, wopts))], {
        type: 'application/octet-stream'
    });
    let textName = moment(new Date()).format('YYYYMMDDHHmmss')  
    saveAs(tmpDown, textName + '.' + type);
};

    //字符串转字符流
   function s2ab(s) {
    if (typeof ArrayBuffer !== "undefined") {
        //1、创建一个字节长度为s.length的内存区域
        let buf = new ArrayBuffer(s.length);
        //2、创建一个指向buf的Unit8视图,开始于0字节,直到缓冲区的末尾
        let view = new Uint8Array(buf);
        //3、返回指定位置的字符的Unicode编码
        for (let i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xff;
        console.log(buf);
        debugger;
        return buf;
    } else {
        let buf = new Array(s.length);
        for (let i = 0; i != s.length; ++i) buf[i] = s.charCodeAt(i) & 0xff;
        return buf;
    }
}
export const saveAs = (obj, fileName) => {
    //1、创建a标签
    let tmpa = document.createElement("a");
    tmpa.download = fileName || "下载";
    //2、创建url指定文件,绑定a标签
    tmpa.href = URL.createObjectURL(obj);
    //3、模拟点击实现下载
    tmpa.click();
    //4、延时释放
    setTimeout(() => {
        //用URL.revokeObjectURL来释放这个object URL
        URL.revokeObjectURL(obj);
    }, 100);
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值