如何vue 导入Excel时 中文键转英文键

288 阅读1分钟

在添加后台员工或人员管理时,往往会出现人数过多,信息量大的问题,这时候就需要用到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)
    }