DataGrid是个可编辑的列表控件,而且可以用已有的输入控件来作为某一列的编辑控件,比如用ComboBox控件来作为某列的编辑控件供用户选择数据,这个时候就要先设置好ComboBox控件的下拉列表项了,在silverlight里怎么做呢?
首先,定义好XAML,如下:
- <data:DataGrid Grid.Row="0" x:Name="gridVariables" RowHeight="20" AutoGenerateColumns="False" BorderThickness="1,1,1">
- <data:DataGrid.Columns>
- <data:DataGridTemplateColumn Header="类型" Width="120">
- <data:DataGridTemplateColumn.CellTemplate>
- <DataTemplate>
- <TextBlock Text="{Binding Type}"/>
- </DataTemplate>
- </data:DataGridTemplateColumn.CellTemplate>
- <data:DataGridTemplateColumn.CellEditingTemplate>
- <DataTemplate>
- <ComboBox >
- </ComboBox>
- </DataTemplate>
- </data:DataGridTemplateColumn.CellEditingTemplate>
- </data:DataGridTemplateColumn>
- </data:DataGrid.Columns>
- </data:DataGrid>
其次,需要定义一个类并由该类的一个属性来提高选项数据来源,如下:
- public class WorkflowVariableTypes
- {
- public List<WorkflowVariableType> WorkflowVariableTypeList
- {
- get
- {
- List<WorkflowVariableType> types = new List<WorkflowVariableType>();
- for (int i = 0; i < 14; i++)
- {
- types.Add(new WorkflowVariableType {Type = (VariableType)i });
- }
- return types;
- }
- }
- }
然后,我们就可以通过用户控件资源的方式声明该类的一个实例,如下:
- <UserControl.Resources>
- <local:WorkflowVariableTypes x:Key="workflowVariableTypes" />
- </UserControl.Resources>
最后,就是使用该资源了,如下:
这个过程有些类似格式化DataGrid里的列数据,而且我们也可获得一个经验,那就是用户控件的资源是个很强大的东西,可以用来引用静态的东西(图片,样式等),也可以引用动态的东西(代码,类)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。