将数据绑定到WPF网格中的组合框

时间:2013-10-23 06:18:16

标签: c# wpf xaml binding

这是我的 XAML代码

    <DataGridTemplateColumn.CellEditingTemplate>
       <DataTemplate>
            <ComboBox Height="22" Name="MyCombobox"  
                      ItemsSource="{Binding RelativeSource={RelativeSource AncestorType=Page},Path=Data._cmbxData}" 
                      DisplayMemberPath="Column1" SelectedValuePath="Column2"></ComboBox>
       </DataTemplate>
    </DataGridTemplateColumn.CellEditingTemplate>

这是我的 CS代码

        DataTable _cmbxData = new DataTable();
        _cmbxData.Columns.Add("Column1", typeof(int));
        _cmbxData.Columns.Add("Column2", typeof(String));

        _cmbxData.Rows.Add(new object[] { 1,"Value1"});
        _cmbxData.Rows.Add(new object[] { 2, "Value2" });
        _cmbxData.Rows.Add(new object[] { 3, "Value3" });

如何在我的Xaml中将此Datatable绑定到Combobox。 ??

谢谢大家

2 个答案:

答案 0 :(得分:0)

这应该有效:

假设:

dt - DataTable

myWindow - XAMLs窗口名称

<Window
Name="myWindow"
...

Col_Name - 所需的列名

<ComboBox Name="MyComboBox" HorizontalAlignment="Left" Margin="181,55,0,0" Width="120" ItemsSource="{Binding Path=dt, ElementName=myWindow}">
        <ComboBox.ItemTemplate>
            <DataTemplate>
                <StackPanel Orientation="Horizontal">
                    <Label Content="{Binding Path=Col_Name}"/>
                </StackPanel>
            </DataTemplate>
        </ComboBox.ItemTemplate>    
    </ComboBox>

或使用RelativeSource

答案 1 :(得分:0)

您的变量 _cmbxData 应声明为您的窗口属性,如下所示:

public DataTable CmbxData { get; set; }

然后您的DataGridTemplateColumn应引用此属性,您可以使用RelativeSource或通过命名您可以访问其属性的窗口。

<Window x:Class="SO1.UI.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="MainWindow" Height="350" Width="525"
    x:Name="mainPage">
<Grid>
    <DataGrid x:Name="dataGridTest">
        <DataGrid.Columns>
            <DataGridTemplateColumn Header="Test">
                <DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                        <TextBlock Text="Test" />
                    </DataTemplate>
                </DataGridTemplateColumn.CellTemplate>
                <DataGridTemplateColumn.CellEditingTemplate>
                    <DataTemplate>
                        <ComboBox Height="22" Name="MyCombobox"  
                          ItemsSource="{Binding ElementName=mainPage , Path=CmbxData}" 
                          DisplayMemberPath="Column1" SelectedValuePath="Column2">            </ComboBox>
                    </DataTemplate>
                </DataGridTemplateColumn.CellEditingTemplate>
            </DataGridTemplateColumn>
        </DataGrid.Columns>
    </DataGrid>
</Grid>

当然你需要将datagrid绑定到一个源... juste,例如这是我的代码隐藏测试:

   public partial class MainWindow : Window
{
    public DataTable CmbxData { get; set; }
    public IList<string> Test { get; set; }
    public MainWindow()
    {
        InitializeComponent();

        CmbxData = new DataTable();
        CmbxData.Columns.Add("Column1", typeof(int));
        CmbxData.Columns.Add("Column2", typeof(String));

        CmbxData.Rows.Add(new object[] { 1, "Value1" });
        CmbxData.Rows.Add(new object[] { 2, "Value2" });
        CmbxData.Rows.Add(new object[] { 3, "Value3" });


        this.Test = new List<string>();
        this.Test.Add("Test 1");
        this.dataGridTest.ItemsSource = this.Test;

    }
}