WPF datagrid 全选全不选

<Window x:Class="WPFTest.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="350" Width="525">
    <Window.Resources>
        <Style  TargetType="DataGridColumnHeader" >
            <Setter Property="FontSize" Value="14" />
            <Setter Property="Background" Value="#FFF4F4F4" />
            <Setter  Property="FontWeight"  Value="Bold"/>
        </Style>

        <Style  TargetType="DataGridRow">
            <Style.Triggers>
                <Trigger Property="IsSelected" Value="True">
                    <Setter Property="BorderBrush" Value="#FFF4F4F4" />
                    <Setter Property="BorderThickness" Value="1" />
                </Trigger>
                <Trigger Property="IsMouseOver" Value="True">
                    <Setter Property="Background" Value="#FFF4F4F4"/>
                </Trigger>
            </Style.Triggers>
        </Style>

        <Style TargetType="DataGridCell">
            <Style.Triggers>
                <Trigger Property="IsSelected" Value="True">
                    <Setter Property="Background" Value="White"/>
                    <Setter Property="BorderThickness" Value="0"/>
                    <Setter Property="Foreground" Value="White"/>
                </Trigger>
            </Style.Triggers>
        </Style>
    </Window.Resources>
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="0"/>
            <RowDefinition Height="0"/>
            <RowDefinition Height="*"/>
            <RowDefinition Height="38"/>
        </Grid.RowDefinitions>
        <Border BorderBrush="#a4a4a4" Grid.Row="2" BorderThickness="1"  Margin="10,5,10,5">
            <DataGrid x:Name="DistributionTaskData"   AlternatingRowBackground="#f1f8ff" SelectionMode="Single" HorizontalContentAlignment="Left"  Margin="5,5,5,5"  ColumnHeaderHeight="25" Grid.Column="0" CanUserAddRows="False" AutoGenerateColumns="False" Background="White" AlternationCount="0" SnapsToDevicePixels="False" BorderBrush="White" GridLinesVisibility="None"  RowHeaderWidth="0" IsEnabled="True" DataContext="{Binding}" CanUserReorderColumns="False" CanUserSortColumns="False" ItemsSource="{Binding}" EnableRowVirtualization="False"  MinRowHeight="30" Focusable="False" MinColumnWidth="100" BorderThickness="0" >
                <DataGrid.Columns >
                    <DataGridTemplateColumn  IsReadOnly="False">
                        <DataGridTemplateColumn.HeaderTemplate>
                            <DataTemplate>
                                <CheckBox  HorizontalAlignment="Center" VerticalAlignment="Center" Click="SelectedAll_Checked" Tag="{Binding}"
                                                   Name="ckApp" />
                             
                            </DataTemplate>
                        </DataGridTemplateColumn.HeaderTemplate>
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <CheckBox Name="cb" Tag="{Binding}"  IsChecked="{Binding IsChecked,Mode=TwoWay}" Click="cb_Click" ></CheckBox>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
                    </DataGridTemplateColumn>
                    <DataGridTextColumn Header="XXXXX"  Binding="{Binding Name1}" ></DataGridTextColumn>
                    <DataGridTextColumn Header="YYYYY" Binding="{Binding Age}"></DataGridTextColumn>
                    <DataGridTextColumn Header="ZZZZZ" Binding="{Binding Addrress}"></DataGridTextColumn>
                </DataGrid.Columns>
            </DataGrid>
        </Border>
        <Button Content="Button" Grid.Row="3" Height="23" HorizontalAlignment="Left" Margin="46,3,0,0" Name="button1" VerticalAlignment="Top" Width="75" Click="button1_Click" />
    </Grid>
</Window>

 

 

 

 

 

 

 

 

 

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.ComponentModel;

namespace WPFTest
{
    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindow : Window
    {
        List<TestData> list = new List<TestData>();
        public MainWindow()
        {
            InitializeComponent();
            this.Loaded += MainWindow_Loaded;
        }

        void MainWindow_Loaded(object sender, RoutedEventArgs e)
        {
            GetData();
            DistributionTaskData.ItemsSource = list;
        }

 

        private void SelectedAll_Checked(object sender, RoutedEventArgs e)
        {
            CheckBox chk1 = (CheckBox)sender;
            List<TestData> vd1 = this.DistributionTaskData.ItemsSource as List<TestData>;
            foreach (var item in vd1)
            {
                item.IsChecked = chk1.IsChecked.Value;
            }
        }
        private void GetData()
        {
            for (int i = 0; i < 13; i++)
            {
                TestData td = new TestData();
                td.Name1 = "text" + i;
                td.Age = i + "";
                td.Addrress = "dizhi" + i;
                list.Add(td);
            }
        }

        private void cb_Click(object sender, RoutedEventArgs e)
        {
            CheckBox chk = (CheckBox)sender;
            TestData vd = chk.Tag as TestData;
            vd.IsChecked = chk.IsChecked.Value;
        }

        private void button1_Click(object sender, RoutedEventArgs e)
        {
            List<TestData> wellApproval = new List<TestData>();
            if ((this.DistributionTaskData.ItemsSource as List<TestData>).Count > 0)
            {
                foreach (var item in this.DistributionTaskData.ItemsSource as List<TestData>)
                {
                    if (item.IsChecked == true)
                    {
                        wellApproval.Add(item);
                    }
                }
            }
            if (wellApproval.Count > 0)
            {
                StringBuilder str = new StringBuilder();
                foreach (var item in wellApproval)
                {
                    str.Append(item.Name1 + "||");
                }
                MessageBox.Show(str.ToString());
            }
        }
    }
    public class TestData : INotifyPropertyChanged
    {
        public void INotifyPropertyChanged(string propertyName)
        {
            if (PropertyChanged != null)
                PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
        }

        public event PropertyChangedEventHandler PropertyChanged;

        private string Name;

        public string Name1
        {
            get { return Name; }
            set { Name = value; }
        }
        private string age;

        public string Age
        {
            get { return age; }
            set { age = value; }
        }
        private string addrress;

        public string Addrress
        {
            get { return addrress; }
            set { addrress = value; }
        }

        private bool isChecked;
        public bool IsChecked
        {
            get { return isChecked; }
            set
            {
                isChecked = value;
                INotifyPropertyChanged("IsChecked");
            }
        }
    }
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在WPF中,可以通过以下方式实现DataGrid全选功能: 1. 首先,需要在XAML文件中创建一个CheckBox来表示全选功能。例如,可以在DataGrid的上方添加一个CheckBox控件,并设置一个命名,如"全选CheckBox"。 2. 接下来,在代码文件中,可以使用DataGrid的SelectionChanged事件来处理全选功能。在事件处理程序中,可以获取到全选CheckBox的状态,然后根据其状态来改变DataGrid中的所有行的选中状态。 3. 在SelectionChanged事件处理程序中,可以使用VisualTreeHelper来遍历DataGrid中的所有行,并根据全选CheckBox的状态改变每一行的选中状态。具体步骤如下: a. 首先,使用VisualTreeHelper.GetChildrenCount方法获取DataGrid中的所有子元素的数量。 b. 然后,使用VisualTreeHelper.GetChild方法来获取每个子元素。 c. 判断获取到的子元素是否为DataGridRow,如果是,则可以使用DataGrid的SelectedItems属性来判断其选中状态并进行更新。 4. 最后,需要在全选CheckBox的Checked和Unchecked事件中调用全选功能的实现代码。例如,可以在Checked事件中将所有行都选中,而在Unchecked事件中将所有行都取消选中。 综上所述,以上是使用WPF实现DataGrid全选功能的基本步骤。按照这种方法,可以实现DataGrid全选功能,并根据全选CheckBox的状态来改变每一行的选中状态。可以将以上代码嵌入到WPF项目中相应的位置并且根据个人需求进行调整。 ### 回答2: 在WPFDataGrid中实现全选的方法如下所示: 1. 首先,我们需要在DataGrid控件中添加一个全选的复选框列。可以使用DataGridTemplateColumn来创建一个模板列,其中包含一个CheckBox控件。 2. 在XAML代码中,我们可以添加以下的代码片段: ```xaml <DataGrid x:Name="myDataGrid"> <DataGrid.Columns> <DataGridTemplateColumn> <DataGridTemplateColumn.Header> <CheckBox x:Name="chkSelectAll" Content="全选" Checked="chkSelectAll_Checked" Unchecked="chkSelectAll_Unchecked"/> </DataGridTemplateColumn.Header> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <CheckBox IsChecked="{Binding IsSelected, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/> </DataTemplate> </DataGridTemplateColumn.CellTemplate> </DataGridTemplateColumn> <!-- 其他列 --> </DataGrid.Columns> </DataGrid> ``` 3. 在代码后台的.cs文件中,我们可以添加以下代码: ```csharp private void chkSelectAll_Checked(object sender, RoutedEventArgs e) { foreach (var item in myDataGrid.ItemsSource) { // 获取数据项中名为"IsSelected"的属性,并将其设置为true PropertyInfo propertyInfo = item.GetType().GetProperty("IsSelected"); propertyInfo.SetValue(item, true); } } private void chkSelectAll_Unchecked(object sender, RoutedEventArgs e) { foreach (var item in myDataGrid.ItemsSource) { PropertyInfo propertyInfo = item.GetType().GetProperty("IsSelected"); propertyInfo.SetValue(item, false); } } ``` 在这个示例中,我们通过遍历DataGrid中的每个数据项,使用反射来获取名为"IsSelected"的属性,并将其设置为true或false来实现全选或取消全选的功能。 请注意,上述示例假设数据项中有一个名为"IsSelected"的布尔属性来表示每一行是否被选中。您可以根据自己的需求调整代码。 ### 回答3: 要实现 WPF DataGrid全选功能,可以按照以下步骤进行操作: 1. 在 XAML 文件中,创建一个 DataGrid 控件,并指定其 Name 属性,以便在后面的代码中引用它。 ```xml <DataGrid x:Name="myDataGrid"> <!-- DataGrid 的列定义 --> </DataGrid> ``` 2. 在代码文件中,定义一个集合来存储 DataGrid 的数据源,并将其绑定到 DataGrid 控件。 ```csharp public ObservableCollection<MyDataModel> MyDataCollection { get; set; } myDataGrid.ItemsSource = MyDataCollection; ``` 3. 添加一个复选框作为全选按钮,并为其添加一个点击事件处理程序。 ```xml <CheckBox x:Name="selectAllCheckBox" Click="SelectAllCheckBox_Click" Content="全选" /> ``` 4. 在点击事件处理程序中,通过遍历 DataGrid 的行,选中或取消选中每一行的复选框。 ```csharp private void SelectAllCheckBox_Click(object sender, RoutedEventArgs e) { CheckBox checkBox = (CheckBox)sender; bool isChecked = checkBox.IsChecked ?? false; foreach (var item in MyDataCollection) { item.IsSelected = isChecked; } } ``` 5. 在 DataGrid 的列定义中,添加一个模板列,其中包含一个复选框,用于选中或取消选中每一行。 ```xml <DataGrid.Columns> <!-- 其他列定义 --> <DataGridTemplateColumn> <DataGridTemplateColumn.HeaderTemplate> <DataTemplate> <!-- 全选按钮的复选框 --> <CheckBox Click="SelectAllCheckBox_Click" IsChecked="{Binding ElementName=selectAllCheckBox, Path=IsChecked, Mode=TwoWay}" /> </DataTemplate> </DataGridTemplateColumn.HeaderTemplate> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <!-- 行的复选框 --> <CheckBox IsChecked="{Binding IsSelected, Mode=TwoWay}" /> </DataTemplate> </DataGridTemplateColumn.CellTemplate> </DataGridTemplateColumn> </DataGrid.Columns> ``` 通过以上步骤,你可以在 WPF DataGrid 中实现全选功能。点击全选复选框时,所有行的复选框会被选中或取消选中,然后可以通过访问数据源的 IsSelected 属性来获取被选中的行。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值