把布尔值转为通俗显示

某些值在数据库存储为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>

 

cs:

 protected string MyStatus(object obj)
    {
        
if (obj == nullreturn 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>

 

 

posted @ 2011-05-25 08:44  Insus.NET  阅读(2654)  评论(11编辑  收藏  举报