vue + elment-ui导入上传excel表格并读取数据(完结版亲测有效!!)

之前试了很多网上的方法都不行,总会出现各种各样的问题,不是这里缺东西就是那里报错,摸索了老半天终于搞定hhhhhh,于是自己写了一份总结,方便需要的同学使用。

首先,这里需要实现的效果为:

当点击<el-button>按钮时,打开文件夹,选择excel表并上传,读取excel表中的内容,并把内容填写至<el-table>之中,如图:

接下来需要做的是安装3个依赖和添加两个js文件:

npm install -S file-saver xlsx(这里其实安装了2个依赖)

npm install -D script-loader

好了,三个依赖安装好了(记得要在main.js文件中引用,不会的同学自行百度)
接着在src中建个文件夹,文件夹名字随意,在文件夹中放入这两个文件:

两个JS文件

接下来,代码部分

<el-upload
            class="upload-demo"
            action=""
            :on-change="handleChange"
            :show-file-list="false"
            :on-remove="handleRemove"
            :file-list="fileListUpload"
            :limit="limitUpload"
            accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/vnd.ms-excel"
            :auto-upload="false">
            <el-button size="small" type="primary" >批量上传</el-button>
            <div slot="tip" class="el-upload__tip">注:只 能 上 传 xlsx / xls 文 件</div>
        </el-upload>
// excel表上传
    handleChange(file, fileList){
    this.fileTemp = file.raw
    // 判断上传文件格式
    if(this.fileTemp){
    if((this.fileTemp.type == 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet') || (this.fileTemp.type == 'application/vnd.ms-excel')){
        this.importfxx(this.fileTemp)
    } else {
        this.$message({
            type:'warning',
            message:'附件格式错误,请删除后重新上传!'
        })
    }
} else {
    this.$message({
        type:'warning',
        message:'请上传附件!'
    })
}
    },
    // 移除excel表
    handleRemove(file,fileList){
        this.fileTemp = null
    },
    importfxx(obj) {
    let _this = this;
    // 通过DOM取文件数据
    this.file = obj
    var rABS = false; //是否将文件读取为二进制字符串
    var f = this.file;
    var reader = new FileReader();
    FileReader.prototype.readAsBinaryString = function(f) {
        var binary = "";
        var rABS = false; //是否将文件读取为二进制字符串
        var pt = this;
        var wb; //读取完成的数据
        var outdata;
        var reader = new FileReader();
        reader.onload = function(e) {
        var bytes = new Uint8Array(reader.result);
        console.log(reader.result)
        var length = bytes.byteLength;
        for(var i = 0; i < length; i++) {
            binary += String.fromCharCode(bytes[i]);
        }
        var XLSX = require('xlsx');
        if(rABS) {
            wb = XLSX.read(btoa(fixdata(binary)), { //手动转化
                type: 'base64'
            });
        } else {
            wb = XLSX.read(binary, {
                type: 'binary'
            });
        }
        outdata = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]]);//outdata就是读取excel内容之后输出的东西
            this.da = [...outdata]
            let arr = []
            this.da.map(v => {
                let obj = {}
                obj.ip = v['ip'] //ip是表的标题
                arr.push(obj)
            })
          
            //return arr
            // 把读取的excel表格中的内容放进tableData2中(这里要改成自己的表的名字)
            _this.tableData2 = _this.tableData2.concat(arr)
        }
        reader.readAsArrayBuffer(f);

    }
    if(rABS) {
        reader.readAsArrayBuffer(f);
    } else {
        reader.readAsBinaryString(f);
    }
    },
发布了4 篇原创文章 · 获赞 1 · 访问量 3155

猜你喜欢

转载自blog.csdn.net/weixin_29344615/article/details/100539221