本文主要介绍了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的实现方法
基础教程推荐
- linux – 如何在Debian Jessie中安装dotnet core sdk 2023-09-26
- C#控制台实现飞行棋小游戏 2023-04-22
- C# windows语音识别与朗读实例 2023-04-27
- ZooKeeper的安装及部署教程 2023-01-22
- 一个读写csv文件的C#类 2022-11-06
- C# List实现行转列的通用方案 2022-11-02
- C# 调用WebService的方法 2023-03-09
- C#类和结构详解 2023-05-30
- winform把Office转成PDF文件 2023-06-14
- unity实现动态排行榜 2023-04-27