C#从枚举值获取对应文本的图文代码详解


本文摘自PHP中文网,作者黄舟,侵删。

这篇文章主要介绍了C# 从枚举值获取对应的文本描述详解的相关资料,需要的朋友可以参考下

C# 从枚举值获取对应的文本描述详解

有时枚举值在显示时,需要显示枚举值对应的文本串。一种方案是在调用的地方使用switch或者if来判断枚举值,然后赋给不同的文本串,但这样一来,如果有较多的地方都用到的时候就会比较麻烦。当然有人说,这种情况下,可以针对这种枚举值封装一个方法,然后来调用。那如果有多个枚举类型都有这样的需求呢?有没有什么比较通用的解决办法?有的。

这里需要用到Description属性,给每个枚举值都赋上一个该属性,然后在该属性中赋上要描述的文本串。比如

1

2

3

4

5

6

7

8

9

#region YesNoEnum

 public enum YesNoEnum

 {

   [Description("是")]

   Yes,

   [Description("否")]

   No

 }

 #endregion

注:Desscription需要引用using System.ComponentModel;

那要如何获取这个Description属性的值呢?我们可以作用反射,代码如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

public static class EnumUtil

 {

   #region FetchDescription

   /// <summary>

   /// 获取枚举值的描述文本

   /// </summary>

   /// <param name="value"></param>

   /// <returns></returns>

   public static string FetchDescription(this Enum value)

   {

     FieldInfo fi = value.GetType().GetField(value.ToString());

     DescriptionAttribute[] attributes =

        (DescriptionAttribute[])fi.GetCustomAttributes(

        typeof(DescriptionAttribute), false);

     return (attributes.Length > 0) ? attributes[0].Description : value.ToString();

   }

   #endregion

 }

注:我们这里写的虽然是静态方法,但是可以适用于所有的Enum类。EnumUtil必须是静态类,而方法也必须是静态方法,同时第一个参数必须是this的,这样才能将方法扩展到Enum类中,以适用到所有的枚举中。

下面是调用代码

1

2

3

YesNoEnum yesNoEnum = YesNoEnum.Yes;

 string description = yesNoEnum.FetchDescription();

 Console.WriteLine(description);

调用的截图如下



从图中可以看到description得到了我们在枚举中指定的Description的文本。同时YesNoEnum的枚举实例增加了扩展方法FetchDescription.

以上就是C#从枚举值获取对应文本的图文代码详解的详细内容!

相关阅读 >>

详细介绍C#实现关闭子窗口而不释放子窗口对象的方法分享

C#基础入门-简单了解注释

C#devexpress gridcontrol日期行的显示格式设置详解(图文)

详解C#winform程序的toolstripbutton自定义背景应用示例源码

C#开发实例-订制屏幕截图工具(九)使用自定义光标和qq截图时的光标(图)

关于C#代码convert.tochar(null);出现异常的详解(图)

C#新建datacolumn类时type类型参数的生成方式的示例代码详解

C#二进制字节数组操作函数 截取字节数组subbyte的示例代码

C#使用oledb连接excel执行insert into语句出现“必须使用一个可更新的查询”的解决办法的示例代码

使用C#给pdf文档添加注释的示例代码分享(图)

更多相关阅读请进入《C#》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...