前言:

  相信各位有碰到过与我类似的问题,当表中存一些状态的字段,无非以下几种形式1.直接写死 如: 正常:1,异常:2 ,还有一种则是写在字典中,再或者就是加在枚举上,前两者对于返回下拉数据源来说比较好处理,直接写死和查数据库,但都有各自的缺点,写死维护比较麻烦,查数据库也没必要,这个时候枚举就可以解决这个问题.

实现逻辑:

  要返回一个List<StartStateEnum>,其中包含枚举类型StartStateEnum的所有字段值,你可以使用反射来实现。以下是一个示例代码,演示了如何将枚举类型中的字段值添加到集合并返回:

 1 using System;
2 using System.Collections.Generic;
3 using System.ComponentModel;
4 using System.Reflection;
5
6 public class Program
7 {
8 public enum StartStateEnum
9 {
10 [Description("启动")]
11 Start = 0,
12
13 [Description("未启动")]
14 NotStart = 1
15 }
16
17 public static void Main(string[] args)
18 {
19 // 获取枚举字段值的集合
20 List<StartStateEnum> enumValues = GetEnumValues<StartStateEnum>();
21
22 // 输出集合中的字段值
23 foreach (var value in enumValues)
24 {
25 Console.WriteLine(value);
26 }
27 }
28
29 public static List<T> GetEnumValues<T>()
30 {
31 // 获取枚举类型
32 Type enumType = typeof(T);
33
34 // 验证是否为枚举类型
35 if (!enumType.IsEnum)
36 {
37 throw new ArgumentException("The specified type is not an enum.");
38 }
39
40 // 获取枚举中的所有字段
41 FieldInfo[] fields = enumType.GetFields(BindingFlags.Public | BindingFlags.Static);
42
43 // 存储字段值的集合
44 List<T> enumValues = new List<T>();
45
46 // 遍历字段并添加字段值到集合
47 foreach (var field in fields)
48 {
49 if (field.FieldType == enumType)
50 {
51 T value = (T)field.GetValue(null);
52 enumValues.Add(value);
53 }
54 }
55
56 return enumValues;
57 }
58 }

在上述示例中,我们定义了一个名为StartStateEnum的枚举类型,其中包含了两个值:StartNotStart。每个值都具有一个DescriptionAttribute,其中包含了对应的描述。

Main方法中,我们调用GetEnumValues方法来获取枚举类型StartStateEnum中的所有字段值,并将返回的字段值集合存储在enumValues变量中。

然后,我们遍历字段值集合,并将每个字段值输出到控制台。

请注意,我们定义了一个名为GetEnumValues的辅助方法,用于获取枚举类型的字段值。该方法使用反射来获取字段的值,并将其添加到集合中。我们还添加了一些验证,以确保传递的类型是有效的枚举类型。

运行以上代码,输出将是:

1 Start 2 NotStart

这证明成功将枚举类型StartStateEnum的字段值添加到集合中并返回。请根据实际情况修改示例代码中的枚举类型和字段处理逻辑。

实现:

  1.创建一个枚举帮助类,并加上上面的逻辑代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks; namespace Yuebon.Commons.Helpers
{
/// <summary>
/// 枚举帮助类
/// </summary>
public static class EnumHelper
{
/// <summary>
/// 获取枚举中所有字段
/// </summary>
/// <typeparam name="T"></typeparam>
/// <returns></returns>
/// <exception cref="ArgumentException"></exception>
public static List<T> GetEnumValues<T>()
{
// 获取枚举类型
Type enumType = typeof(T); // 验证是否为枚举类型
if (!enumType.IsEnum)
{
throw new ArgumentNullException("指定的类型不是枚举。");
} // 获取枚举中的所有字段
FieldInfo[] fields = enumType.GetFields(BindingFlags.Public | BindingFlags.Static); // 存储字段值的集合
List<T> enumValues = new List<T>(); // 遍历字段并添加字段值到集合
foreach (var field in fields)
{
if (field.FieldType == enumType)
{
T value = (T)field.GetValue(null);
enumValues.Add(value);
}
} return enumValues;
}
}
}

  2.调用和结果:

// GetDescription 获取枚举描述的扩展方法,感兴趣的小伙伴可以去看我之前的文章~
result.ResData = EnumHelper.GetEnumValues<StartStateEnum>().Select(d => new KeyValue { Key = Convert.ToInt32(d).ToString(), Value = d.GetDescription() });

 结尾:

  通过枚举将表中状态已获取下拉数据源的形式响应给前端,代码可维护性和扩展性的优势非常的明显,也不必要去浪费数据库的资源,是一个非常不错的方法,当然了,一些变化比较多业务逻辑代码较少的一些字段还是建议在字典中维护起来,如角色,类型等,

  因为最近工作比较忙,博客比较少更新还请我为数不多的13位粉丝见谅哈哈哈,创作不易,如果对你有帮助不妨留下一颗免费的小红星吧~

  

c# 如何将枚举以下拉数据源的形式返回给前端的更多相关文章

  1. java操作poi生成excel.xlsx(设置下拉框)下载本地和前端下载

    需求:导入excel表格,如果excel有错误,将错误的地方标红,在把数据以excel的形式写出,供用户下载解决方案:1.以实体类的方式接收excel并解析(创建两个集合一个接收正常的数据一个接收错误 ...

  2. 【Java Web】项目通用返回模块ServerResponse:枚举code状态码、泛型返回值、序列化注解限制数据

    一.枚举类编写ResponseCode package com.boulderaitech.common; /** * 编写枚举类的步骤 * (1)编写所需的变量 * (2)编写枚举类构造方法 * ( ...

  3. C#中的LINQ 基础

    1.LINQ的数据源 必须可枚举的,即必须是数组或者集合 (继承了IEnumerable<T>接口就可以,注意是IEnumerable<T>,不是IEnumerable接口,不 ...

  4. 【转】【C#】C# 不常用关键字

    1.__arglist 让我们先从__arglist开始. __arglist是用来给方法传送参数.通常我们是通过函数头部指定的参数列表给方法传递参数的.如果我们想要给方法传递一组新的参数,我们需要重 ...

  5. C#基础:关键字和数据类型

    [关键字]  #region 和 #endregion 关键字可以折叠代码  checked 用于整型算术运算时控制当前环境中的溢出检查  unchecked 操作符用于整型算术运算时控制当前环境中的 ...

  6. 【温故而知新-万花筒】C# 异步编程 逆变 协变 委托 事件 事件参数 迭代 线程、多线程、线程池、后台线程

    额基本脱离了2.0 3.5的时代了.在.net 4.0+ 时代.一切都是辣么简单! 参考文档: http://www.cnblogs.com/linzheng/archive/2012/04/11/2 ...

  7. DotNet基础

    DotNet基础 URL特殊字符转义 摘要: URL中一些字符的特殊含义,基本编码规则如下: 1.空格换成加号(+) 2.正斜杠(/)分隔目录和子目录 3.问号(?)分隔URL和查询 4.百分号(%) ...

  8. 一个C#程序员学习微信小程序的笔记

    客户端打开小程序的时候,就将代码包下载到本地进行解析,首先找到了根目录的 app.json ,知道了小程序的所有页面. 在这个Index页面就是我们的首页,客户端在启动的时候,将首页的代码装载进来,通 ...

  9. 自定义CRM系统

    写在前面 之前在windows上写代码逻辑.搞前端等花了很长时间,跑通之后一直没往centos上部署, 昨天尝试部署下,结果发现静态文件找不到 =='' 由于写了2个组件: - arya model的 ...

  10. springBoot的搭建使用记录

    一: 首次搭建:https://blog.csdn.net/u013187139/article/details/68944972 整合mybatis: https://www.jianshu.com ...

随机推荐

  1. nginx重启和操作

    在linux操作系统中,重启nginx 1.当不知道nginx所在目录时,需要先查找到nginx的位置  查看ngnix位置(master process 后面的就是 nginx的目录): ps -e ...

  2. Kubernetes(k8s)实现IPv4/IPv6网络双栈

    背景 如今IPv4IP地址已经使用完毕,未来全球会以IPv6地址为中心,会大力发展IPv6网络环境,由于IPv6可以实现给任何一个设备分配到公网IP,所以资源是非常丰富的. 配置hosts [root ...

  3. docker方式实现minio数据持久化离线安装

    保存镜像 root@hello:~# docker pull minio/minio Using default tag: latest latest: Pulling from minio/mini ...

  4. Disruptor-简单使用

    前言 Disruptor是一个高性能的无锁并发框架,其主要应用场景是在高并发.低延迟的系统中,如金融领域的交易系统,游戏服务器等.其优点就是非常快,号称能支撑每秒600万订单.需要注意的是,Disru ...

  5. Java设计模式 —— 建造者模式

    8 建造者模式 8.1 建造者模式概述 Builder Pattern:将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 建造者模式可以将部件本身和它们的组装过程分开,关注如 ...

  6. PopupWindow点击空白区域消失

    下面三个条件必须要有,要在popupWindow显示之前调用popupWindow.setOutsideTouchable(true);popupWindow.setFocusable(true);p ...

  7. 【D01】Django中实现带进度条的倒计时功能(简易版)

    首先说明简易版是只有一个 倒计时 和一个 进度条,页面加载后自动开始计时,下次计时需要手动刷新页面. 后续会更新实现完整的倒计时功能的文章 前期准备 前端框架 你需要准备一些前端框架:Bootstra ...

  8. SQL优化(一)

    1.什么是SQL优化 SQL语句的优化是将性能低下的SQL语句转换成目的相同但是性能优异的SQL语句. 2.为什么需要学习SQL优化 SQL语句是对数据库进行操作的惟一途径,对数据库系统的性能起着决定 ...

  9. JUC(六)堵塞队列与线程池

    堵塞队列 简介 def:在多线程中实现高效.安全的数据传输,主要是通过一个共享的队列,使得数据能够从一端输入,从另一端输出 当队列是空的,取数据的线程就会被堵塞,直到其他线程往空的队列中添加数据 当队 ...

  10. .NET Core反射获取带有自定义特性的类,通过依赖注入根据Attribute元数据信息调用对应的方法

    前言 前段时间有朋友问道一个这样的问题,.NET Core中如何通过Attribute的元数据信息来调用标记的对应方法.我第一时间想到的就是通过C#反射获取带有Custom Attribute标记的类 ...