在WPF中,将DataTable绑定到DataGrid似乎很简单,但实际上有时会遇到问题。 在许多情况下,将DataTable绑定到DataGrid不会显示任何数据,甚至不会显示列标题。 这是因为DataTable的Columns集合中的每个列必须有一个ColumnName。
以下是一个简单的代码示例,说明如何将DataTable正确地绑定到DataGrid:
DataTable dt = new DataTable();
dt.Columns.Add("ID");
dt.Columns.Add("Name");
dt.Columns.Add("Address");
for (int i = 1; i <= 3; i++)
{
DataRow row = dt.NewRow();
row["ID"] = i;
row["Name"] = "Name " + i;
row["Address"] = "Address " + i;
dt.Rows.Add(row);
}
// 设置DataGrid
dataGrid.AutoGenerateColumns = false;
dataGrid.ItemsSource = dt.DefaultView;
// 添加列到DataGrid
DataGridTextColumn columnID = new DataGridTextColumn();
columnID.Header = "ID";
columnID.Binding = new Binding("ID");
dataGrid.Columns.Add(columnID);
DataGridTextColumn columnName = new DataGridTextColumn();
columnName.Header = "Name";
columnName.Binding = new Binding("Name");
dataGrid.Columns.Add(columnName);
DataGridTextColumn columnAddress = new DataGridTextColumn();
columnAddress.Header = "Address";
columnAddress.Binding = new Binding("Address");
dataGrid.Columns.Add(columnAddress);
在上面的示例中,我们创建一个带有三个列的DataTable,然后将其绑定到DataGrid。 我们设置了DataGrid的AutoGenerateColumns属性为false,以便手动添加数据列。 然后我们将每个DataGridTextColumn绑定到DataColumn的ColumnName属性。
通过这种方式,我们可以正确地将DataTable绑定到DataGrid,并显示数据。