vue 获取excel文件表头 .xls

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不会自动上传

},

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值