来自:http://blog.csdn.net/crazy_frog/article/details/7705442

方法一:

绑定

  1. enum TestEnum {zero=0,one=1,two=2}
  2. ComboBox cbo = new ComboBox();
  3. cbo.DataSource = System.Enum.GetNames(typeof(TestEnum));
  4. TestEnum  test = TestEnum .one;
  5. cbo.SelectedIndex = this.cbo.FindString(test.ToString());
  6. 取值
  7. TestEnum testenum = (TestEnum)Enum.Parse(typeof(TestEnum) ,cbo.SelectedItem.ToString() ,false)

方法二:

  1. foreach (var v in typeof(AA).GetFields())
  2. {
  3. if (v.FieldType.IsEnum == true)
  4. {
  5. this.comboBox1.Items.Add(v.Name);
  6. }
  7. }
  8. this.comboBox1.SelectedIndex = 1;

方法三:

反射,枚举,绑定下拉框

  1. public static class EnumManager<TEnum>
  2. {
  3. private static DataTable GetDataTable()
  4. {
  5. Type enumType = typeof(TEnum); // 获取类型对象
  6. FieldInfo[] enumFields = enumType.GetFields();    //获取字段信息对象集合
  7. DataTable table = new DataTable();
  8. table.Columns.Add("Name", Type.GetType("System.String"));
  9. table.Columns.Add("Value", Type.GetType("System.Int32"));
  10. //遍历集合
  11. foreach (FieldInfo field in enumFields)
  12. {
  13. if (!field.IsSpecialName)
  14. {
  15. DataRow row = table.NewRow();
  16. row[0] = field.Name;   // 获取字段文本值
  17. row[1] = Convert.ToInt32(field.GetRawConstantValue());        // 获取int数值
  18. //row[1] = (int)Enum.Parse(enumType, field.Name); 也可以这样
  19. table.Rows.Add(row);
  20. }
  21. }
  22. return table;
  23. }
  24. public static void SetListControl(ListControl list)
  25. {
  26. list.DataSource = GetDataTable();
  27. list.DataTextField = "Name";
  28. list.DataValueField = "Value";
  29. list.DataBind();
  30. }
  31. }
  32. public enum BookingStatus {
  33. 未提交 = 1,
  34. 已提交,
  35. 已取消,
  36. 已完成 = 6
  37. }
  38. EnumManager<BookingStauts>.SetListControl(ddlBookingStatus);
  39. EnumManager<TicketStatus>.SetListControl(rblTicketStatus);

C# 枚举绑定到ComboBox的更多相关文章

  1. C# 利用反射将枚举绑定到下拉框

    前言:反射(Reflection)是.NET提供给开发者的一个强大工具,尽管作为.NET框架的使用者,很多时候不会用到反射.但在一些情况下,尤其是在开发一些基础框架或公共类库时,使用反射会使系统架构更 ...

  2. 【Winform】DataTable绑定到ComboBox

    我们从数据库中查询出来的数据存放在Datatable中 1.DataTable绑定到ComboBox上 cmbRole.DataSource = datatable; cmbRole.DisplayM ...

  3. 你想要的都在这里,ASP.NET Core MVC四种枚举绑定方式

    前言 本节我们来讲讲在ASP.NET Core MVC又为我们提供了哪些方便,之前我们探讨过在ASP.NET MVC中下拉框绑定方式,这节我们来再来重点看看枚举绑定的方式,充分实现你所能想到的场景,满 ...

  4. Winform开发中如何将数据库字段绑定到ComboBox控件

    最近开始自己动手写一个财务分析软件,由于自己也是刚学.Net不久,所以自己写的的时候遇到了很多问题,希望通过博客把一些印象深刻的问题记录下来. Winform开发中如何将数据库字段绑定到ComboBo ...

  5. ASP.NET Core MVC四种枚举绑定方式

    前言 本节我们来讲讲在ASP.NET Core MVC又为我们提供了哪些方便,之前我们探讨过在ASP.NET MVC中下拉框绑定方式,这节我们来再来重点看看枚举绑定的方式,充分实现你所能想到的场景,满 ...

  6. [WinForm] DataGridView 绑定 DT && ComboBox 列绑定 Dict

    一  需求介绍 一般像枚举类型的数据,我们在数据库里存储着诸如(1.2.3.4-)或者("001"."002"."003"-)此类,但是界面 ...

  7. MVC 枚举绑定 DropDownList

    /// <summary> /// 枚举转化下拉列表数据集 /// </summary> /// <param name="type">类型&l ...

  8. 在WPF中使用变通方法实现枚举类型的XAML绑定

    问题缘起 WPF的分层结构为编程带来了极大便利,XAML绑定是其最主要的特征.在使用绑定的过程中,大家都普遍的发现枚举成员的绑定是个问题.一般来说,枚举绑定多出现于与ComboBox配合的情况,此时我 ...

  9. c# select标签绑定枚举,并以Description做Text显示

    今天在做项目时遇到一个问题: 开发中有些字段是枚举类型如 Dept 企业表中可能有个字段 Property 性质 0:事业单位,1:私企,2:外企,但有时我们不会单独为性质这个字段定义一张表, 而是在 ...

随机推荐

  1. 用jstack工具分析java程序

    最近做项目时遇到了一个问题,我的多个采集线程中,有一个线程经常挂起,线程并没有死掉,但是一直采集不到数据,为了解决这个问题,用到了jstack. 首先查找到java进程的pid,ps -ef|grep ...

  2. oracle数据库连接字符串

    不在项目加入tsname.ora的托管写法: <add name="CONN" connectionString="data source=127.0.0.1:15 ...

  3. MPMoviePlayerController 视频播放器—IOS开发

    MPMoviePlayerController 与AVAudioPlayer有点类似,前者播放视频,后者播放音频,不过也有很大不同,MPMoviePlayerController 可以直接通过远程UR ...

  4. java 对excel操作 读取、写入、修改数据;导出数据库数据到excel

    ============前提加入jar包jxl.jar========================= // 从数据库导出数据到excel public List<Xskh> outPu ...

  5. c语言-格式控制字符 %XXd 用法

    d格式字符 用来输出十进制整数,有以下几种用法: 1. %d, 按整型数据的实际长度输出. 2.  %md,m为指定输出的整型位数的宽度,如果整型数据的实际位数小于m,则左端补以空格,如果大于m,则按 ...

  6. SQL函数集合

    1. PATINDEX ( '%pattern%' , expression ) 返回pattern字符串在表达式expression里第一次出现的位置,起始值从1开始算. pattern字符串在ex ...

  7. as [Frame]元标签

    [Frame(factoryClass="XXX_Class")] 利用Frame元标签.在主SWF类名上面添加 [Frame(factoryClass="加载类类名&q ...

  8. OpenStack tokens id获取测试

     

  9. Linq使用Group By经验总结

    1.计数 var q = from p in db.Products group p by p.CategoryID into g select new { g.Key, NumProducts = ...

  10. 单步运行linux kernel ?

    如果能给linux kernel打log,如果能单步运行,如果能像普通应用程序那样,step by step的查看程序跑哪里了.. 该多好?这是一个梦想,但从未实现过:因为那是kernel,不是应用程 ...