本文主要介绍了C#中通过反射将枚举元素加载到ComboBo的实现方法,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
一、前言
做过系统参数设置的同学们,肯定遇到过要提供一系列具有相同特点的选项供用户选择。最初级的做法是在窗体上增加一个下拉框控件,手工填写Items选项。然后运行时可以下拉选择。那如果有百八十个参数都是这种方式怎么办?
上述做法弊端很明显。那么如何灵活的实现这个需求呢?
二、思路
在代码中定义枚举类型,然后在窗体加载时,将枚举类型的元素(描述信息)加载到下拉框中,这样以后增加或修改了枚举元素后,下拉框中时刻保持的是最新的数据。再运用上反射机制,多个下拉框可以复用同一个加载方法。代码量会大幅度减少,同时可读性和可维护性提高了许多。
三、上代码
1. 首先定义一个枚举,例如:
using SharedBaseProject.Utils;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
namespace SharedBaseProject.Common.CarPosition
{
public class Direction
{
/// <summary>
/// 方向
/// </summary>
public enum Enum_Direction
{
/// <summary>
/// 默认值
/// </summary>
[Description("未指定")]
None = -1,
/// <summary>
/// 上
/// </summary>
[Description("上")]
Up = 0,
/// <summary>
/// 下
/// </summary>
[Description("下")]
Down = 1,
/// <summary>
/// 左
/// </summary>
[Description("左")]
Left = 2,
/// <summary>
/// 右
/// </summary>
[Description("右")]
Right = 3
}
}
}
2. 引入模板方法,将枚举转换为List的代码封装为静态方法:
using System;
using System.Collections.Generic;
using System.Text;
namespace SharedBaseProject.CustomType
{
public class EnumberEntity
{
/// <summary>
/// 枚举的描述
/// </summary>
public string Description { set; get; }
/// <summary>
/// 枚举名称
/// </summary>
public string EnumName { set; get; }
/// <summary>
/// 枚举对象的值
/// </summary>
public int EnumValue { set; get; }
}
}
using SharedBaseProject.CustomType;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Reflection;
namespace SharedBaseProject.Utils
{
public class EnumUtil
{
/// <summary>
/// 枚举转换为List
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="startValue">从哪个一个元素开始获取</param>
/// <returns></returns>
public static List<EnumberEntity> EnumToList<T>(int startValue = 0)
{
List<EnumberEntity> list = new List<EnumberEntity>();
foreach (var e in Enum.GetValues(typeof(T)))
{
if (Convert.ToInt32(e) < startValue)
{
continue;
}
EnumberEntity m = new EnumberEntity();
object[] objArr = e.GetType().GetField(e.ToString()).GetCustomAttributes(typeof(DescriptionAttribute), true);
if (objArr != null && objArr.Length > 0)
{
DescriptionAttribute da = objArr[0] as DescriptionAttribute;
m.Description = da.Description;
}
m.EnumValue = Convert.ToInt32(e);
m.EnumName = e.ToString();
list.Add(m);
}
return list;
}
}
}
3. 封装一个方法,通过反射将获取到的List赋予下拉框。
入参为下拉框、以及具体的枚举类型:
/// <summary>
/// 加载下拉框选项
/// </summary>
private void loadComboBoxItems(ComboBox comboBox, Type type, int startValue = 0)
{
// Get the generic type definition
MethodInfo method = typeof(EnumUtil).GetMethod("EnumToList", BindingFlags.Public | BindingFlags.Static);
// Build a method with the specific type argument you're interested in
method = method.MakeGenericMethod(type);
// The "null" is because it's a static method
List<EnumberEntity> listBaiduPositionMode = (List<EnumberEntity>)method.Invoke(null, new object[] { startValue });
if (listBaiduPositionMode == null || listBaiduPositionMode.Count < 1)
{
return;
}
int iCount = listBaiduPositionMode.Count;
for (int i = 0; i < iCount; i++)
{
comboBox.Items.Add(listBaiduPositionMode.ElementAt(i).Description);
}
}
4. 在窗体上设置一个下拉框,命名direction:
5. 调用,参数1为下拉框控件名称,参数2的Enum_Direction为之前定义的枚举类型:
loadComboBoxItems(direction, typeof(Enum_Direction));
运行后效果如图:
如果有多个类似参数,每个只需一句代码调用即可。怎么样,是不是很方便?
到此这篇关于C#中通过反射将枚举元素加载到ComboBo的实现方法的文章就介绍到这了,更多相关C# 枚举加载到ComboBo内容请搜索得得之家以前的文章希望大家以后多多支持得得之家!
本文标题为:C#中通过反射将枚举元素加载到ComboBo的实现方法
- Unity3D实现渐变颜色效果 2023-01-16
- WPF使用DrawingContext实现绘制刻度条 2023-07-04
- Oracle中for循环的使用方法 2023-07-04
- .NET CORE DI 依赖注入 2023-09-27
- c# 模拟线性回归的示例 2023-03-14
- Unity Shader实现模糊效果 2023-04-27
- C# 使用Aspose.Cells 导出Excel的步骤及问题记录 2023-05-16
- 如何使用C# 捕获进程输出 2023-03-10
- user32.dll 函数说明小结 2022-12-26
- 在C# 8中如何使用默认接口方法详解 2023-03-29