vue 获取excel文件表头 .xls

该代码段展示了一个在上传XLSX文件前进行格式和大小验证的过程。首先,它导入了xlsx库,然后在beforeUpload函数中检查文件扩展名为.xls且文件大小小于5MB。接着,使用FileReader读取文件并转换为二进制,进一步解析Excel数据。最后,提取表头信息并准备用于后续操作的数据结构。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import XLSX from 'xlsx'; //导入包

beforeUpload(file) {

let vm = this;

vm.files = file;

const loading = this.$loading({

lock: true,

text: 'Loading',

spinner: 'el-icon-loading',

background: 'rgba(0, 0, 0, 0.7)'

});

const extension = file.name.split('.')[1] === 'xls'

const isLt2M = file.size / 1024 / 1024 < 5

if (!extension) {

vm.$message.warning('上传模板只能是 xls格式!')

return false

}

if (!isLt2M) {

vm.$message.warning('上传模板大小不能超过 5MB!')

return false

}

var excelFile;

var reader = new FileReader();

reader.readAsBinaryString(file);

reader.onload = function(e) {

var data = e.target.result;

excelFile = XLSX.read(data, {

type: "binary"

});

var headers_key = new Array();

var headers = new Array();

var optionList = new Array();

var str = XLSX.utils.sheet_to_json(

excelFile.Sheets[excelFile.SheetNames[0]]

);

for (var key in str[1]) {

headers_key.push(key); //获取表头key

}

for (var i = 0; i < headers_key.length; i++) {

headers.push(str[1][headers_key[i]]); //获取表头

}

for (var i = 0; i < headers_key.length; i++) {

var str = {"id":i+'',"value":headers_key[i]}

optionList.push(str)

}

}

vm.centerDialogVisible = true;

loading.close();

return // 返回false不会自动上传

},

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值