微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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">
  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里的列数据,而且我们也可获得一个经验,那就是用户控件的资源是个很强大的东西,可以用来引用静态的东西(图片,样式等),也可以引用动态的东西(代码,类)。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐