我使用DataTable作为DataGrid的源代码:
dt.Columns.Add("Update?", typeof(Boolean));
dt.Columns.Add("Emulator", typeof(String));
dt.Columns.Add("Path", typeof(String));
...
dataGrid1.ItemsSource = dt.DefaultView;
DataGrid的XAML代码:
<DataGrid AutoGenerateColumns="True" Height="133" HorizontalAlignment="Left" Margin="0,81,0,0" Name="dataGrid1" VerticalAlignment="Top" Width="688" >
<DataGrid.Columns>
<DataGridCheckBoxColumn CanUserResize="False" Header="Update?" />
<DataGridTextColumn CanUserResize="False" Header="Emulator" IsReadOnly="False"/>
<DataGridTextColumn CanUserResize="False" Header="Path" IsReadOnly="False"/>
</DataGrid.Columns>
</DataGrid>
因此,如果DataTable为空,我会得到一个空的DataGrid,显示三个标题名称 如果DataTable包含项,则DataGrid会获取额外的列,而不是填充已存在的列。
DataGrid如何填充现有列?
答案 0 :(得分:6)
设置AutoGenerateColumns="False"
如果将此属性设置为true
,则会自动创建列
还需要设置绑定,示例代码:
<DataGrid Name="DG1" AutoGenerateColumns="False" ItemsSource="{Binding}">
<DataGrid.Columns>
<DataGridCheckBoxColumn Header="Online Order?" IsThreeState="True" Binding="{Binding OnlineOrderFlag}" />
</DataGrid.Columns>
</DataGrid>