checklistbox(checklistbox有哪些使用技巧)
一、c#checklistbox属性items中成员的text和value属性有什么区别
text属于要显示的内容
value是提供内容用什么表示
相当于
一般表示男女是都用(0、1)
而不用男女
一般都是出现在下拉框
的东西
省市什么的
都用特殊的值来表示
所显示的
男女就用text
表示
用来表示男女的值(0和1)用value
(0和1)主要是存在数据库里的
、
不知道我这样说明白不??
二、checklistbox
使用CheckListBox轻松管理您的任务清单
任务清单是我们生活中必不可少的一部分,它可以帮助我们更好地规划时间、提高工作效率。而CheckListBox则是一款非常实用的工具,可以帮助我们快速、轻松地管理任务清单。本文将为大家介绍如何使用CheckListBox来管理您的任务清单。
什么是CheckListBox?
CheckListBox是一款基于WindowsForms的控件,它可以让用户在列表框中选择多个选项。与ListBox不同的是,CheckListBox中的每个选项都有一个复选框,用户可以通过勾选或取消勾选来选择或取消选择某个选项。
使用CheckListBox管理任务清单的步骤
步骤一:创建CheckListBox控件
在VisualStudio中创建一个WindowsForms应用程序,然后将CheckListBox控件拖放到窗体上。
步骤二:添加任务清单
在CheckListBox中添加任务清单。可以通过以下两种方式添加:
在VisualStudio的属性窗口中设置Items属性,手动添加任务清单。
在代码中使用Add方法添加任务清单。
步骤三:管理任务清单
通过勾选或取消勾选复选框来管理任务清单。可以通过以下代码获取选中的任务:
foreach(objectitemincheckListBox1.CheckedItems)
{
stringtask=item.ToString();
//处理选中的任务
}
CheckListBox的优点
使用CheckListBox管理任务清单有以下优点:
可以快速、轻松地管理任务清单。
可以同时选择多个任务。
可以通过代码获取选中的任务。
三、c#wpf 中有没有checklistbox
实际项目中常常要实现有CheckBox列表框。但是WPF没有自带这样的一个控件,下面就用Style来实现这样的功能。而对于CheckBox列表框,又常常会有一个Select All的CheckBox来表示当前列表框的选择状态。这个功能也会被包含在下面的示例之中。效果如下图所示。
对于单纯的,没有后台数据绑定的情况下,这个功能可以用ItemContainerStyle来实现。代码如下:
复制代码
CheckListBoxItemContainerStyle
<Style x:Key="CheckListBoxItemContainerStyle"
TargetType="{x:Type ListBoxItem}">
<!--Set it un-focusable, becaues the CheckBox in it should be focusable and only it.-->
<Setter Property="Focusable" Value="False"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ListBoxItem}">
<CheckBox Content="{TemplateBinding Content}"
ContentTemplate="{TemplateBinding ContentTemplate}"
ContentTemplateSelector="{TemplateBinding ContentTemplateSelector}"
IsChecked="{Binding IsSelected, RelativeSource={RelativeSource TemplatedParent}}"/>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
复制代码
其中要对Content和ContentTemplate等属性进行绑定,以方便对其进行扩展,保证其通用性。这个Style一般会放在Application级别的Resource中。
对于有后台数据绑定的情况,一般会有双个属性要绑定,一个是CheckBox里的Content,一个是CheckBox的IsChecked。绑定的路径,只有在用一个Style的ListBox那里才知道,所以并不能写在这个Style里,否则会破坏这个Style的通用性。比较合理的方式是基于这个现有的Style进行修改。
对于下面的数据类。
DataItem Class
我们需要下面这个有针对性的Style来应用数据绑定。
复制代码
DataItemCheckListBoxStyle
<Style x:Key="DataItemCheckListBoxStyle"
TargetType="{x:Type ListBox}"
BasedOn="{StaticResource{x:Type ListBox}}">
<Setter Property="ItemTemplate">
<Setter.Value>
<DataTemplate>
<TextBlock Text="{Binding Name}"/>
</DataTemplate>
</Setter.Value>
</Setter>
<Setter Property="ItemContainerStyle">
<Setter.Value>
<Style TargetType="{x:Type ListBoxItem}"
BasedOn="{StaticResource CheckListBoxItemContainerStyle}">
<Setter Property="IsSelected"
Value="{Binding IsEnabled}"/>
<Setter Property="Margin" Value="2,2,0,0"/>
</Style>
</Setter.Value>
</Setter>
<Setter Property="SelectionMode" Value="Multiple"/>
</Style>
复制代码
在上面的Style中,使用了ItemTemplate来指定CheckBox里的Content绑定到的属性,并把ListBoxItem的IsSelected绑定数据的相应属性上。由于这个Style是针对特定数据写的,所以应当放置在使用这个Style的ListBox所在的Window的Resource中。
当然,也可以为ListBox添加两个绑定类型的Attached Property来实现一个通用的Style。不过这个Property一样要在使用的地方设置,其实没有太大区别。有兴趣的读者可以自己试一下。
对于Select All这个CheckBox而言,用Attached Property倒是很方便。给CheckBox添加一个SyncTarget属性指向要同步的ListBox,就可以在Window.xaml.cs之外的地方同步CheckBox和ListBox了。代码如下:
ToggleButtonProperty
使用方式也很简单。如下代码所示。
复制代码
用法
<DockPanel Margin="12">
<CheckBox Content="Select All"
Margin="0,0,0,5"
DockPanel.Dock="Top"
ext:ToggleButtonProperty.SyncTarget="{Binding ElementName=checkListBox}"/>
<ListBox x:Name="checkListBox"
Style="{StaticResource DataItemCheckListBoxStyle}"
ItemsSource="{Binding Path=Items, ElementName=mainWindow}"/>
</DockPanel>