中秋不加班:js枚举值enums在业务中的应用案例

本文分享一个js枚举值enums在业务中的应用

不使用枚举值面临的问题

1、问题1

比如写vue组件的时候,需要多层传递参数,如果是二选一还好,传递一个bool值,true/false。

如果是有很多值,传递0、1、2、3…,过短时间来看代码,不知道什么心情

2、问题2

如果不使用枚举值,代码中到处是字符串 ‘red’, 有一天后端接口说这个枚举值需要修改一下,处处修改代码,稍有不慎,将面临雪崩,导致一些未能及时发现的问题

正常来说,定义好枚举值之后,不应该随意修改,可是接口代码在后端同学手里,你自然无法控制

当然也可以说服后端同学不要改

如何使用枚举值

1、第一步:定义枚举值

// enums.js

// 颜色枚举值,可以是字符串,也可以是数值
export const colorEnum = {
    
    
  RED: 'red',
  GREEN: 'green',
  BLUE: 'blue',
}


// 颜色枚举值和显示值对应关系,也可以包含其他字段属性
// 该数据也可以用于select下拉选择
export const colorOptions = [
  {
    
    
    label: '红色',
    value: colorEnum.RED,
  },
  {
    
    
    label: '绿色',
    value: colorEnum.GREEN,
  },
  {
    
    
    label: '蓝色',
    value: colorEnum.BLUE,
  },
]


// 可能在不同的场景下,显示不一样的值,也可支持传递额外参数
export function getColorLabel(colorValue) {
    
    
  for (let item of colorOptions) {
    
    
    if (item.value == colorValue) {
    
    
      return item.label
    }
  }
}

2、第二步:使用枚举值

使用场景一:真实值 和 枚举值 做逻辑判断

import {
    
     colorEnum } from './enums.js'

// 可以通过接口返回的 真实值 和 枚举值 做逻辑判断
let res = {
    
     color: 'red' }

// 最好使用 ===,减少不必要的错误
console.log(colorEnum.RED == res.color);
// true

使用场景二:真实值 转换 显示值

后端接口返回一个list列表,列表没有返回显示值,需要通过真实值进行转换显示

import {
    
     getColorLabel } from './enums.js'

// 这个时候,服务端的接口返回了一个值 red
// 通过 值 获取 显示内容,显示到界面
let colorLabel = getColorLabel('red');
console.log(colorLabel);
// 红色

猜你喜欢

转载自blog.csdn.net/mouday/article/details/126509610