silverlight之How To:设置ComboBox控件的数据源当ComboBox用来作为DataGrid的某列的编辑控件时

DataGrid是个可编辑的列表控件,而且可以用已有的输入控件来作为某一列的编辑控件,比如用ComboBox控件来作为某列的编辑控件供用户选择数据,这个时候就要先设置好ComboBox控件的下拉列表项了,在silverlight里怎么做呢?

首先,定义好XAML,如下:

 

  1. <data:DataGrid Grid.Row="0" x:Name="gridVariables" RowHeight="20" AutoGenerateColumns="False" BorderThickness="1,1,1,1">
  2.                         <data:DataGrid.Columns>
  3.                             <data:DataGridTemplateColumn Header="类型" Width="120">
  4.                                 <data:DataGridTemplateColumn.CellTemplate>
  5.                                     <DataTemplate>
  6.                                         <TextBlock Text="{Binding Type}"/>
  7.                                     </DataTemplate>
  8.                                 </data:DataGridTemplateColumn.CellTemplate>
  9.                                 <data:DataGridTemplateColumn.CellEditingTemplate>
  10.                                     <DataTemplate>
  11.                                         <ComboBox >
  12.                                         </ComboBox>
  13.                                     </DataTemplate>
  14.                                 </data:DataGridTemplateColumn.CellEditingTemplate>
  15.                             </data:DataGridTemplateColumn>
  16.                        </data:DataGrid.Columns>
  17.                     </data:DataGrid>

其次,需要定义一个类并由该类的一个属性来提高选项数据来源,如下:

  1. public class WorkflowVariableTypes
  2.     {
  3.         public List<WorkflowVariableType> WorkflowVariableTypeList
  4.         {
  5.             get
  6.             {
  7.                 List<WorkflowVariableType> types = new List<WorkflowVariableType>();
  8.                 for (int i = 0; i < 14; i++)
  9.                 {
  10.                     types.Add(new WorkflowVariableType {Type = (VariableType)i });
  11.                 }
  12.                 return types;
  13.             }
  14.         }
  15.     }

然后,我们就可以通过用户控件资源的方式声明该类的一个实例,如下:

  1. <UserControl.Resources>
  2.         <local:WorkflowVariableTypes x:Key="workflowVariableTypes" />
  3.     </UserControl.Resources>

 

最后,就是使用该资源了,如下:

  1. <data:DataGridTemplateColumn.CellEditingTemplate>
  2.                                     <DataTemplate>
  3.                                         <ComboBox ItemsSource="{Binding WorkflowVariableTypeList, Source={StaticResource workflowVariableTypes}}">
  4.                                         </ComboBox>
  5.                                     </DataTemplate>
  6.                                 </data:DataGridTemplateColumn.CellEditingTemplate>

这个过程有些类似格式化DataGrid里的列数据,而且我们也可获得一个经验,那就是用户控件的资源是个很强大的东西,可以用来引用静态的东西(图片,样式等),也可以引用动态的东西(代码,类)。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值