本文分享一个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); // 红色