美文网首页
2020-05-11 前端js解决spring boot 枚举类

2020-05-11 前端js解决spring boot 枚举类

作者: rub1cky | 来源:发表于2020-05-11 08:50 被阅读0次

前端js解决spring boot 枚举类返回对象的扁平化函数


const toString = Object.prototype.toString

const codeMap = new Set([
  'scope',
  'status',
  'operatorType',
  'goodsType',
  'fromType',
  'salaryUnit',
  'defaultType'
])
// 去除对象中非必要对象
export function recurseObject(obj) {
  let newObj = {}

  if (!['[object Object]', '[object Array]'].includes(toString.call(obj))) {
    return obj
  }

  if (toString.call(obj) === '[object Object]') {
    for (let key in obj) {
      if (toString.call(obj[key]) === '[object Object]') {
        if (codeMap.has(key)) {
          newObj[key] = obj[key]['name']
          newObj[key + 'Code'] = obj[key]['code']
          newObj[key + 'Text'] = obj[key]['text']
        } else {
          newObj[key] = recurseObject(obj[key])
        }
      } else if (toString.call(obj[key]) === '[object Array]') {
        newObj[key] = map(obj[key], item => recurseObject(item))
      } else {
        newObj[key] = obj[key]
      }
    }
  }

  if (toString.call(obj) === '[object Array]') {
    return obj.map(item => recurseObject(item))
  }

  return newObj
}

ObjectIn

{
  scope: {
        code: 1
        name: "CUSTOMER"
        text: "Customer"
        textEn: "Customer"
  }
}

ObjectOut

{
  scope: "CUSTOMER",
  scopeText: "CUSTOMER",
  scopeCode: 1
}

相关文章

网友评论

      本文标题:2020-05-11 前端js解决spring boot 枚举类

      本文链接:https://www.haomeiwen.com/subject/ijsynhtx.html