继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

把布尔值转为通俗显示

kala16
关注TA
已关注
手记 260
粉丝 18
获赞 134

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

 

 

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP