之前试了很多网上的方法都不行,总会出现各种各样的问题,不是这里缺东西就是那里报错,摸索了老半天终于搞定hhhhhh,于是自己写了一份总结,方便需要的同学使用。
首先,这里需要实现的效果为:
当点击<el-button>按钮时,打开文件夹,选择excel表并上传,读取excel表中的内容,并把内容填写至<el-table>之中,如图:
接下来需要做的是安装3个依赖和添加两个js文件:
npm install -S file-saver xlsx(这里其实安装了2个依赖)
npm install -D script-loader
好了,三个依赖安装好了(记得要在main.js文件中引用,不会的同学自行百度)
接着在src中建个文件夹,文件夹名字随意,在文件夹中放入这两个文件:
接下来,代码部分:
<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);
}
},