温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

使用vue导出excel遇到的坑怎么解决

发布时间:2022-04-07 13:37:11 来源:亿速云 阅读:281 作者:iii 栏目:开发技术

这篇“使用vue导出excel遇到的坑怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“使用vue导出excel遇到的坑怎么解决”文章吧。

    vue导出excel遇到的坑

    需求

    Vue+element UI el-table下的导出当前所有数据到一个excel文件里。

    先按照网上的方法,看看有哪些坑

    准备工作

    1、安装依赖:yarn add xlsx file-saver -S

    2、在放置需要导出功能的组件中引入

    import FileSaver from "file-saver";
    import XLSX from "xlsx";

    3、HTML中的设置,简单来说就是给需要导出的table标签el-table上加一个id:如outTable,对应下面的exportExcel方法中的 document.querySelector(‘#outTable‘)

       //导出当前表格
    exportCurrent:function(){
        var wb = XLSX.utils.table_to_book(document.querySelector('#outTable')) //表格id
        var wbout = XLSX.write(wb, { bookType: 'xlsx', bookSST: true, type: 'array' })
        try {
            FileSaver.saveAs(new Blob([wbout], { type: 'application/octet-stream' }), 'sheet.xlsx')  //文件名
        } catch (e) { if (typeof console !== 'undefined') console.log(e, wbout) }
        return wbout
    },


    我们来看一下原始数据

    使用vue导出excel遇到的坑怎么解决

    接下来再来看一下导出的结果

    使用vue导出excel遇到的坑怎么解决

    哎???我订单编号跟银行卡号咋成了科学计数法了??

    还有我的时间,时分秒呢??

    原因是因为数字太长了,需要使用excel的文本格式才能显示正常

    经过各种搜索,最终解决方法如下:

    exportExcel() {
          var xlsxParam = { raw: true };//转换成excel时,使用原始的格式
          var wb = XLSX.utils.table_to_book(document.querySelector("#outTable"),xlsxParam);
          var wbout = XLSX.write(wb, {
            bookType: "xlsx",
            bookSST: true,
            type: "array"
          });
          try {
            FileSaver.saveAs(
              new Blob([wbout], { type: "application/octet-stream;charset=utf-8" }),
              "sheetjs.xlsx"
            );
          } catch (e) {
            if (typeof console !== "undefined") console.log(e, wbout);
          }
          return wbout;
        },


    再来看我们的数据

    使用vue导出excel遇到的坑怎么解决

    大功告成。
     

    vue导出excel表报错处理

    Excel表导出功能需要将请求中的 responseType 设置为 blob,也就是说请求只能接收Excel文件,json数据没法处理

    此时可以根据 Response 的 Content-Type值类判断处理,如果值 为 application/json,则先将返回的数据转换成字符串,然后再转换为 JSON
     

            // 导出
            downLoad(){
                const fileReader = new FileReader() // 第一步创建文件对象
                const loading = this.$loading({
                    lock: true,
                    text: '导出加载中···',
                    spinner: 'el-icon-loading',
                    background: 'rgba(0, 0, 0, 0.7)'
                });
                const data = {
                    equipmentName: this.searchForm.equipmentName,
                    equipmentCode: this.searchForm.equipmentCode,
                };
                download('/api/mfg-mes/equipmentVersion/exportStandardWorkTime', data).then(res => {
                    fileReader.onloadend = () => { // 定义方法
                        if (res.type === 'application/json') { // 第三步进行判断
                            const jsonData = JSON.parse(fileReader.result) // 说明是普通对象数据,后台转换失败
                            // 后台信息
                            // console.log(jsonData,'fileReader')
                            this.$message.error(jsonData.msg)
                            loading.close();
                        }else{
                            downloadFile(res, '信息表', 'xlsx')
                            loading.close();
                        }
                    }
                    fileReader.readAsText(res)
                }).catch(err => {
                    console.log(err);
                })
            },

    以上就是关于“使用vue导出excel遇到的坑怎么解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI