文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>SilverLight C#中char(1)数据类型页面显示解决办法(讨论)

SilverLight C#中char(1)数据类型页面显示解决办法(讨论)

时间:2011-04-13  来源:记忆逝去的青春

背景

在目前很多项目中为了实现数据库的可移植性性,把我们常见的byte数据类型改为了char(1)数据类型。。。

在页面显示的时候,就比较难处理了。数据读出之后变为杯具的string型,显示在界面上 感觉光秃秃的。。。

而且在绑定CheckBox等只有两种状态的控件时,转换时比较困难。。。

因此,我们就会想 是不是可以把他在界面上显示的时候变为是或否,在增加的时候变为bool值,使他能够绑定CheckBox???

对策

有人会说 在读取数据的时候,把他判断一下不就得了呀。。。

问题是:我们现在有三种类型,不!应该叫状态。。。string型的“是”/“否”、true/false、string类型的“1”/“0”

三个状态。。。在数据读取的时候转化有点纠结。。。。

我的方案

可以从类的属性下手。。。。

为string的“1”/“0”建立两个辅助属性,一个是string类型一个是bool类型。。。

在绑定的时候,需要那个就绑定那个属性。。。不用再费力的判断。。。

保存到数据库的属性不变。。。还是为“1”/“0”

看代码:

C#
 /// <summary>
/// 采购类型默认值(new)
/// </summary>
public string PurType_DefaultFlag { set; get; }

public string DefaultFlagString
{
get
{
_defaultflagstring
= PurType_DefaultFlag == "0" ? "" : "";
return _defaultflagstring;
}
set
{
_defaultflagstring
= value;
PurType_DefaultFlag
= value == "" ? "0" : "1";
}
}

public bool DefaultFlagBool
{
get
{
_defaultflagbool
= PurType_DefaultFlag == "0" ? true : false;
return _defaultflagbool;
}
set
{
_defaultflagbool
= value;
PurType_DefaultFlag
= value ? "0" : "1";
}
}

界面绑定

 <sdk:DataGrid AutoGenerateColumns="False" Name="dgSettType" Margin="5"
ItemsSource
="{Binding PurTypeList}"
SelectedItem
="{Binding PurTypeModel}" IsReadOnly="True">
<sdk:DataGrid.Columns>
<sdk:DataGridTextColumn Header="采购类型名称" Binding="{Binding PurType_Name}"/>
<sdk:DataGridTextColumn Header="采购类型默认值" Binding="{Binding DefaultFlagString}"/>
<sdk:DataGridTextColumn Header="排序列" Binding="{Binding R_OrderSN}" />
<sdk:DataGridTextColumn Header="说明" Binding="{Binding PurType_Remark}"/>
</sdk:DataGrid.Columns>
</sdk:DataGrid>

界面绑定

<sdk:Label Content="采购类型名称:" Style="{StaticResource labStyle}"/>
<Controls:TextBoxEx AllowEmpty="False" Grid.Column="1" Style="{StaticResource txtStyle}" Text="{Binding PurTypeModel.PurType_Name,Mode=TwoWay,ValidatesOnExceptions=True,NotifyOnValidationError=True}"/>

<sdk:Label Grid.Row="1" Content="采购类型默认值:" Style="{StaticResource labStyle}"/>
<CheckBox x:Name="chks" Grid.Row="1" Grid.Column="1" Margin="5,15,0,0" IsChecked="{Binding DefaultFlagBool,Mode=TwoWay}"

<sdk:Label Grid.Row
="2" Content="排序列:" Style="{StaticResource labStyle}"/>
<TextBox Grid.Row="2" Grid.Column="1" Style="{StaticResource txtStyle}" Text="{Binding PurTypeModel.R_OrderSN,Mode=TwoWay}"/>

<sdk:Label Grid.Row="3" Content="备 注:" Style="{StaticResource labStyle}"/>
<TextBox Grid.Row="3" Grid.Column="1" Style="{StaticResource txtStyle}" Text="{Binding PurTypeModel.PurType_Remark,Mode=TwoWay}"/>

保存的时候保存,他的原值属性即可。。。

效果预览:

相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载