WPF 选中datagrid列头中checkbox则全选对应整列checkbox

这个问题纠结很长时间,今个解决了啊!归结到底还是对WPF不是太了解啊,当你做完以后才发现原来是自己想的复杂了,所以啊考虑问题还是要从这门语言的本身出发,

这样有时候就少走些弯路了。^^

xaml对应代码:

 

  <DataGrid>
  <DataGrid.Columns>
    <DataGridCheckBoxColumn Binding="{Binding Path=IsSelected,RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type DataGridRow}}}">
          <DataGridCheckBoxColumn.HeaderTemplate>
                <DataTemplate>
                      <CheckBox x:Name="ckbSelectedAll" Content="全选" Checked="ckbSelectedAll_Checked" Unchecked="ckbSelectedAll_Unchecked" IsChecked="False" />
                </DataTemplate>
         </DataGridCheckBoxColumn.HeaderTemplate>
    </DataGridCheckBoxColumn>
   <DataGridTextColumn Header="序号" Width="*" Binding="{Binding SequenceNumber}"  IsReadOnly="True"/>
   <DataGridTextColumn Header="编号" Width="*" Binding="{Binding Number}" IsReadOnly="True"/>
.....................................
...................................
  <DataGrid.Columns>
  <DataGrid>

C#代码:
 /// <summary>
        /// 全选
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void ckbSelectedAll_Checked(object sender, RoutedEventArgs e)
        {
            this.dgrid.SelectAll();
        }
 
        /// <summary>
        /// 全不选
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void ckbSelectedAll_Unchecked(object sender, RoutedEventArgs e)
        {
            this.dgrid.UnselectAll();
        }
你可以试一下了。
下面是我的软件截图:

 

转载于:https://www.cnblogs.com/leeice/archive/2012/10/23/2736029.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现 WPF DataGrid 选中单元格或列头选中整列,并更换背景颜色,可以使用以下代码: 1. 在 DataGrid 标签添加 SelectionUnit="Cell" 属性,以确保单元格被选中时整行不会被选中。 2. 在 DataGrid 添加 SelectionChanged 事件,以便在选中单元格时更改单元格背景颜色。 3. 在 DataGrid 添加 MouseLeftButtonDown 事件,以便在单击列头时更改整列的背景颜色。 以下是示例代码: ```xml <DataGrid SelectionUnit="Cell" SelectionChanged="DataGrid_SelectionChanged" MouseLeftButtonDown="DataGrid_MouseLeftButtonDown"> <DataGrid.Resources> <SolidColorBrush x:Key="SelectedBackgroundBrush" Color="LightBlue"/> </DataGrid.Resources> <DataGrid.CellStyle> <Style TargetType="{x:Type DataGridCell}"> <Style.Triggers> <Trigger Property="IsSelected" Value="True"> <Setter Property="Background" Value="{StaticResource SelectedBackgroundBrush}"/> </Trigger> </Style.Triggers> </Style> </DataGrid.CellStyle> <DataGrid.ColumnHeaderStyle> <Style TargetType="{x:Type DataGridColumnHeader}"> <EventSetter Event="MouseLeftButtonDown" Handler="DataGrid_MouseLeftButtonDown"/> </Style> </DataGrid.ColumnHeaderStyle> </DataGrid> ``` 在代码,我们定义了一个名为 SelectedBackgroundBrush 的资源,用于存储选中单元格的背景颜色。然后,我们使用 CellStyle 触发器来更改选中单元格的背景颜色。我们还使用 ColumnHeaderStyle 事件设置器来处理列头的 MouseLeftButtonDown 事件,以更改整列的背景颜色。 在代码后台,我们可以使用以下代码来更改整列的背景颜色: ```csharp private void DataGrid_MouseLeftButtonDown(object sender, MouseButtonEventArgs e) { if (e.ClickCount == 1) { var columnHeader = e.OriginalSource as DataGridColumnHeader; if (columnHeader != null) { var column = columnHeader.Column; var cells = column.GetCellContent(DataGrid.Columns[column.DisplayIndex].GetCellContent(DataGrid.SelectedItem as DependencyObject)).Parent as DataGridCellsPresenter; foreach (var cell in cells.Items) { var dataGridCell = cell as DataGridCell; dataGridCell.Background = (SolidColorBrush)Resources["SelectedBackgroundBrush"]; } } } } ``` 在代码后台,我们使用 DataGridColumnHeader 实例、列索引和 DataGridCellsPresenter 实例来获取整列的所有单元格,并更改它们的背景颜色。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值