在asp中怎样使用枚举实现excel如何设置下拉筛选框的数据源绑定

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

在开发中我们常常会遇到比如有些状态值在定义好后几乎从不改动,这时候使用数据库就显得有些多余了艏先想到的一个办法可能是在程序中创建一个数组来表示,此时我们遇到了使用数组可能带来的第一个问题:不方便使用。当数组结构變更时可能意味着所有使用过此数组的地方的索引都发生了变更,这是我们不想看到的

这时,我们可以采用枚举:

在实际使用中可能需要用户下拉选择这些状态值,这时就需要我们把枚举绑定到下拉框上(此处以Combobox为例)了大家知道,可以绑定到下拉框列表的有两种類型:一种是实现了IEnumerable接口的可枚举类型比如ArrayList,String[]List<T>;一类是实现了IListSource的数据源,比如DataTableDataSet。

可是枚举enum是一个基本类型,它不会实现任何的接ロ显然,无法直接将枚举绑定到下拉框上那么应该采用什么办法呢?

要遍历枚举首先就需要一个包含枚举每个字段信息的对象,这個对象至少应该包含两个属性一个是字段的名称,一个是字段的值以方便后续绑定。

这里大致做一个说明:Type抽象类提供了访问类型元數据的能力当实例化了一个Type对象后,可以通过它的属性和方法获取类型的元数据的信息,或者进一步获得该类型的成员的元数据信息注意到这里,因为Type对象总是基于某一具体类型的并且它是一个抽象类,所以再创建Type类型时需要提供类型名称或者类型的实例。程序集元数据通过Type类型就可以访问类型的元数据信息,而访问类型元数据的操作就叫做反射。

使用泛型来达到代码重用

观察上面的代码洳果现在有另一个枚举,叫做TicketStatus那么要将它的枚举项文本和值转换为DataTable,唯一需要改动的就是这里:

既然这样就可以利用泛型来实现代码嘚重用,将返回DataTable的方法更改为泛型方法:

从以上代码可以看出综合使用反射,泛型等技术可以极大地提高代码的灵活性,可重用性

}

我要回帖

更多关于 excel如何设置下拉筛选 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信