某些值在数据库存储为BIT,在asp.net显示时,它会显示为True或False。但实际情况之下,我们需要它显示通俗语言表达。如某种状态为开或关等。
在asp.net显示,可以有好几种去显示,
第一种,你可以使用CheckBox来表示状态,True将显示选中的效果,反之,是非选中的效果。而使用CheckBox也有两种情形,一种是CheckBox摆放在非Data控件模板中,直接放在网页中
<asp:CheckBox ID="CheckBox1" runat="server" />
cs:
this.CheckBox1.Checked = (bool)dataRow["Status"];
另外一种就是摆放在Data控件中,如Gridview,DataList,Repeater等。状态 :
<asp:CheckBox ID="CheckBox1" runat="server" Checked='<%# Eval("Status")%>' />
第二种,是使用Label来显示:
<ItemTemplate>
<asp:Label ID="Label1" runat="server" Text='<%# MyStatus(Eval("Status"))%>'></asp:Label>
</ItemTemplate>
<asp:Label ID="Label1" runat="server" Text='<%# MyStatus(Eval("Status"))%>'></asp:Label>
</ItemTemplate>
cs:
protected string MyStatus(object obj)
{
if (obj == null) return string.Empty;
if (bool.Parse(obj.ToString()))
return "开";
else
return "关";
}
{
if (obj == null) return string.Empty;
if (bool.Parse(obj.ToString()))
return "开";
else
return "关";
}
第三种,就是你不想写cs,直接在.aspx页面去作判断:
<%# (bool)Eval("Status") ? "开":"关" %>
第四种,就是Insus.NET使用的方法,直接在数据库处理好了。用CASE函数或RIGHT JOIN 均可。具体参考:
http://www.cnblogs.com/insus/articles/1944849.html
在.aspx显示,如下写法,显示结果为“开”或“关”:
<asp:Label ID="Label1" runat="server" Text='<%# Eval("Status")%>'></asp:Label>