中秋不加班: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);
// 红色

相关文章
|
4月前
|
监控 负载均衡 JavaScript
有哪些有效的方法可以优化Node.js应用的性能?
有哪些有效的方法可以优化Node.js应用的性能?
280 69
|
4月前
|
JavaScript 前端开发
如何减少Node.js应用中的全局变量?
如何减少Node.js应用中的全局变量?
159 43
|
5月前
|
前端开发 搜索推荐 JavaScript
如何通过DIY.JS快速构建出一个DIY手机壳、T恤的应用?
DIY.JS 是一款基于原生 Canvas 的业务级图形库,专注于商品定制的图形交互功能,帮助开发者轻松实现个性化设计。适用于 T 恤、手机壳等多种商品场景。它自带丰富功能,无需从零构建,快速集成到项目中。通过创建舞台、添加模型、定义 DIY 区域和添加素材四个步骤即可完成基础用法。支持在线演示体验,文档详细,易上手。
185 57
|
4月前
|
监控 算法 JavaScript
公司局域网管理视域下 Node.js 图算法的深度应用研究:拓扑结构建模与流量优化策略探析
本文探讨了图论算法在公司局域网管理中的应用,针对设备互联复杂、流量调度低效及安全监控困难等问题,提出基于图论的解决方案。通过节点与边建模局域网拓扑结构,利用DFS/BFS实现设备快速发现,Dijkstra算法优化流量路径,社区检测算法识别安全风险。结合WorkWin软件实例,展示了算法在设备管理、流量调度与安全监控中的价值,为智能化局域网管理提供了理论与实践指导。
112 3
|
5月前
|
存储 JavaScript 前端开发
|
6月前
|
JavaScript 前端开发 算法
JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码)
Array.sort() 是一个功能强大的方法,通过自定义的比较函数,可以处理各种复杂的排序逻辑。无论是简单的数字排序,还是多字段、嵌套对象、分组排序等高级应用,Array.sort() 都能胜任。同时,通过性能优化技巧(如映射排序)和结合其他数组方法(如 reduce),Array.sort() 可以用来实现高效的数据处理逻辑。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
6月前
|
JavaScript 前端开发 API
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
6月前
|
JavaScript 前端开发 Java
深入理解 JavaScript 中的 Array.find() 方法:原理、性能优势与实用案例详解
Array.find() 是 JavaScript 数组方法中一个非常实用和强大的工具。它不仅提供了简洁的查找操作,还具有性能上的独特优势:返回的引用能够直接影响原数组的数据内容,使得数据更新更加高效。通过各种场景的展示,我们可以看到 Array.find() 在更新、条件查找和嵌套结构查找等场景中的广泛应用。 在实际开发中,掌握 Array.find() 的特性和使用技巧,可以让代码更加简洁高效,特别是在需要直接修改原数据内容的情形。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一
|
6月前
|
监控 JavaScript 前端开发
MutationObserver详解+案例——深入理解 JavaScript 中的 MutationObserver:原理与实战案例
MutationObserver 是一个非常强大的 API,提供了一种高效、灵活的方式来监听和响应 DOM 变化。它解决了传统 DOM 事件监听器的诸多局限性,通过异步、批量的方式处理 DOM 变化,大大提高了性能和效率。在实际开发中,合理使用 MutationObserver 可以帮助我们更好地控制 DOM 操作,提高代码的健壮性和可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
MutationObserver详解+案例——深入理解 JavaScript 中的 MutationObserver:原理与实战案例
|
7月前
|
JavaScript 前端开发 索引
40个JS常用使用技巧案例
大家好,我是V哥。在日常开发中,JS是解决页面交互的利器。V哥总结了40个实用的JS小技巧,涵盖数组操作、对象处理、函数使用等,并附带案例代码和解释。从数组去重到异步函数,这些技巧能显著提升开发效率。先赞再看后评论,腰缠万贯财进门。关注威哥爱编程,全栈开发就你行!
199 16