zoukankan      html  css  js  c++  java
  • silverlight之How To:设置ComboBox控件的数据源当ComboBox用来作为DataGrid的某列的编辑控件时

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

    首先,定义好XAML,如下:

    <data:DataGrid Grid.Row="0" x:Name="gridVariables" RowHeight="20" AutoGenerateColumns="False" BorderThickness="1,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>
     

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

    <data:DataGridTemplateColumn.CellEditingTemplate>
                                        <DataTemplate>
                                            <ComboBox ItemsSource="{Binding WorkflowVariableTypeList, Source={StaticResource workflowVariableTypes}}">
                                            </ComboBox>
                                        </DataTemplate>
                                    </data:DataGridTemplateColumn.CellEditingTemplate>
    这个过程有些类似格式化DataGrid里的列数据,而且我们也可获得一个经验,那就是用户控件的资源是个很强大的东西,可以用来引用静态的东西(图片,样式等),也可以引用动态的东西(代码,类)。

  • 相关阅读:
    react-navigation
    react
    generator-react-webpack
    安装Eclipse反编译插件(jadclipse)
    Python爬虫学习笔记3:基本库的使用
    Python爬虫学习笔记2:爬虫基础
    Python爬虫学习笔记1:request、selenium、ChromeDrive、GeckoDriver等相关依赖安装
    Python学习笔记28:面向对象进阶及 hashlib
    Python学习笔记27:反射,类的内置方法
    Python学习笔记26:封装、@property、@staticmethod和@classmethod装饰器方法、反射getattr()
  • 原文地址:https://www.cnblogs.com/lifuyun/p/lifuyun09091804.html
Copyright © 2011-2022 走看看