我需要在gridview中显示枚举的名称 按数据表返回其数值
我将其用于其他专栏
<asp:BoundField DataField="Name" HeaderText="User Name" />
我需要将它用于枚举以显示枚举性别
的字符串值<asp:BoundField DataField="Gender" HeaderText="Gender" />
答案 0 :(得分:8)
试试这个解决方案
<asp:TemplateField HeaderText="Category">
<ItemTemplate>
<div>
<%# Enum.GetName(typeof(GlobalLibrary.Constants.Category),Convert.ToInt32(Eval("Category"))) %>
</div>
</ItemTemplate>
</asp:TemplateField>
答案 1 :(得分:1)
它帮助了我:) 然后我发现这个更简单
<asp:TemplateField HeaderText="Gender">
<ItemTemplate><%#(MyGenderEnum)Eval("Gender")%></ItemTemplate>
</asp:TemplateField>
答案 2 :(得分:1)
如果您更喜欢VB.NET:
<asp:TemplateField HeaderText="Status" SortExpression="VisibilityStatus">
<ItemTemplate>
<%# [Enum].GetName(GetType(VisibilityStatusEnum), Eval("VisibilityStatus"))%>
</ItemTemplate>
</asp:TemplateField>
答案 3 :(得分:0)
这个版本在VB.NET中对我有用:
<asp:TemplateField HeaderText="Gender">
<ItemTemplate><%# CType(Eval("Gender"), Gender).ToString() %></ItemTemplate>
</asp:TemplateField>
有趣的是,它没有使用DirectCast而不是CType,并且在我添加ToString()之前仍然显示整数。在我的情况下,我还必须为我的枚举添加命名空间。