0

我一直在让自己发疯,我希望我只是错过了一些明显的东西。

我有一个DataGrid我想绑定到一个 in-memory DataTable。将 AutoGenerateColumns 设置为 true,我可以编辑字段并将更改传播到数据表,一切都很好。问题是我想为“状态”字段设置一个下拉组合框。然后我设置AutoGenerateColumnsfalse手动添加了 XAML 中的列标题。当我这样做时,我无法再编辑这些字段并让更改持续存在,而是在我点击离开后每个字段都是空白的。我在调试期间检查了 Datagrid 列的状态,发现绑定读取为空。关于我做错了什么的任何想法?

XAML 代码:

<DataGrid Margin="31,29,0,29" Name="dgTickets" RowEditEnding="dgTickets_RowEditEnding" AutoGenerateColumns="False">
        <DataGrid.Columns>
            <DataGridTextColumn Header="ID #" x:Name="ID" />
            <DataGridTextColumn Header="Customer Name" x:Name="CustomerName" />
            <DataGridTextColumn Header="Phone #" x:Name="Phone"/>
            <DataGridComboBoxColumn Header="Status" x:Name="Status"/>
            <DataGridCheckBoxColumn Header="Bool?" x:Name="bool1"/>
            <DataGridCheckBoxColumn Header="Bool?" x:Name="bool2"/>
            <DataGridCheckBoxColumn Header="Bool?" x:Name="bool3"/>
            <DataGridTextColumn Header="Notes" x:Name="Notes"/>
        </DataGrid.Columns>
    </DataGrid>

我用于创建 DataTable 并将其关联的 C# 代码:

    //add columns
        column = new DataColumn("ID", System.Type.GetType("System.String")); //two piece constructor - adds header string and data type
        dbTable.Columns.Add(column); //adds the column to the table

        column = new DataColumn("CustomerName", System.Type.GetType("System.String"));
        dbTable.Columns.Add(column);

        column = new DataColumn("Phone#", System.Type.GetType("System.String"));
        dbTable.Columns.Add(column);

        column = new DataColumn("Status", System.Type.GetType("System.String"));

        dbTable.Columns.Add(column);

        column = new DataColumn("bool1", System.Type.GetType("System.Boolean"));
        dbTable.Columns.Add(column);

        column = new DataColumn("bool2", System.Type.GetType("System.Boolean"));
        dbTable.Columns.Add(column);

        column = new DataColumn("bool3", System.Type.GetType("System.Boolean"));
        dbTable.Columns.Add(column);

        column = new DataColumn("Notes", System.Type.GetType("System.String"));
        dbTable.Columns.Add(column);
        //add rows
        row = dbTable.NewRow(); 

        dbTable.Rows.Add(row); 

        dbTable.AcceptChanges();
        dgTickets.ItemsSource = dbTable.DefaultView;

任何建议表示赞赏。我尝试了几种不同的方法来让这两个元素一起工作,但是如果手动定义标题,我似乎无法正确绑定两个元素。

4

1 回答 1

1

我认为您只需将绑定扔在那里,例如:

<DataGridTextColumn Header="Customer Name" x:Name="CustomerName" Binding={Binding path=CustomerName} />
于 2012-05-07T00:05:19.500 回答