18

我有数据表作为 DataGrid 的项目源,这个数据表有很多列。是否可以在不创建新表的情况下显示几列而不是全部?

4

3 回答 3

26

是的。只需标记AutoGenerateColumns=False并手动定义您的列。您可以使用普通的文本绑定列、复选框列、自定义 XAML 模板列等,如您在文档中所见。

<DataGrid ItemsSource="{Binding DataSource}" AutoGenerateColumns="False" >
    <DataGrid.Columns>
    <DataGridTextColumn Header="Simple Value"
                      Binding="{Binding SimpleValue}" Width="*" />
     <DataGridTemplateColumn Width="*" Header="Complex Value">
        <DataGridTemplateColumn.CellTemplate>
          <DataTemplate>
            <StackPanel>
               <TextBox Text="{Binding ComplexValue}"/>
               <TextBox Text="{Binding ComplexValue2}"/>
            </StackPanel>
          </DataTemplate>
        </DataGridTemplateColumn.CellTemplate>
      </DataGridTemplateColumn>
    </DataGrid.Columns>
  </DataGrid>
于 2012-05-10T13:37:48.793 回答
7

此外,您可以处理DataGrid.AutoGeneratingColumn事件并为您不想显示的列设置e.Cancel = true。这样您就不必手动定义要显示的列。

于 2012-05-10T13:55:36.240 回答
6

是的,非常是的。如果您的表结构和列名保持不变,则在 Datagrid XAML 中设置AutoGenerateColums = False并手动创建所有列。

<dg:DataGrid Name="mydg" ItemsSource="{Binding Data}" AutoGenerateColumns="False">
 <dg:DataGrid.Columns>
  <dg:DataGridTextColumn Header="Col 0" Binding="{Binding FirstColumnName}" />
  <dg:DataGridTextColumn Header="Col 1" Binding="{Binding SecondColumnName}" />
 </dg:DataGrid.Columns>
</dg:DataGrid>

然后在代码隐藏中简单地提供 Source like

mydg.ItemSource = Data.DefaultView;

现在,当您的 DataTable 包含列时FirstColumnNameSecondColumnName它们将被数据绑定到您的 Datagrid。

于 2012-05-10T13:35:09.043 回答