在添加后台员工或人员管理时,往往会出现人数过多,信息量大的问题,这时候就需要用到excel导入.
在导入数据时,数组中的中文键需要转换为英文键.例如excel中读入的是姓名,而后端需要的是username
封装一个函数,处理如下字段数据
const mapInfo = {
入职日期: 'timeOfEntry',
手机号: 'mobile',
姓名: 'username',
转正日期: 'correctionTime',
工号: 'workNumber',
部门: 'departmentName',
聘用形式: 'formOfEmployment'
}
1.循环数组,获取每一项数据.
2.获取中文健数组 用 Object.keys() 返回一个数组,数组里面是每个中文健
3.获取中文健对应的英文值
4.重新定义每一项的值,把中文键里的值赋新对象做值
具体代码见下
async handleSuccess({ results, header }) {
// 处理数据
const mapInfo = {
入职日期: 'timeOfEntry',
手机号: 'mobile',
姓名: 'username',
转正日期: 'correctionTime',
工号: 'workNumber',
部门: 'departmentName',
聘用形式: 'formOfEmployment'
}
var newResults = results.map((item) => {
// 3. 定义一个空对象,重新定义数组中的每一项
var obj = {}
// 1. 获取中文键数组
var cnkeys = Object.keys(mapInfo)
cnkeys.forEach((key) => {
// 2. 获取中文键对应的英文值
var enkey = mapInfo[key]
// 4. 重新定义每一项的值
// 5.解决excel时间转换问题 formatExcelDate
if (enkey === 'timeOfEntry' || enkey === 'correctionTime') {
obj[enkey] = new Date(formatExcelDate(item[key]))
}
obj[enkey] = item[key]
})
return obj
})
console.log(newResults, 46)
const res = await importEmployee(newResults)
}