简体   繁体   English

使用复选框和“删除”按钮从WPF Datagrid删除多行

[英]Delete Multiple Rows From WPF Datagrid using Checkbox and Delete button

I have a DataGrid that contains a checkbox. 我有一个包含一个复选框的DataGrid。 I would like to delete all the rows from the DataGrid where the checkbox is checked by clicking on a delete button. 我想通过单击删除按钮从DataGrid删除选中复选框的所有行。 The XAML for my datagrid is shown below. 我的数据网格的XAML如下所示。

    <DataGrid x:Name="orders" Grid.Row="4" Background="AliceBlue" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" AutoGenerateColumns="False"  >
        <DataGrid.Columns>
            <DataGridCheckBoxColumn  Header="Select" Binding="{Binding Path=IsSelected, Mode=TwoWay, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type DataGridRow}}}" ></DataGridCheckBoxColumn>
            <DataGridTextColumn Header="Item Name" Binding="{Binding Path=Name}" ></DataGridTextColumn>
        </DataGrid.Columns>
    </DataGrid>

I would like to write code for click button to delete all the rows where the checkbox is checked like so. 我想为单击按钮编写代码,以删除选中复选框的所有行。

    private void btnDelete_Click(object sender, RoutedEventArgs e)
    {
        //Delete logic here

    }

How do I achieve this? 我该如何实现? NB: I'm using EntityFramework and not ADO. 注意:我使用的是EntityFramework,而不是ADO。 the datagrid is bound to an observable collection of type Order like ObservableCollection<Order> datagrid绑定到Order类型的可观察集合,例如ObservableCollection<Order>

First make sure the DataGrid allows multi-selection via the SelectionMode 首先确保DataGrid允许通过SelectionMode进行多重选择

SelectionMode="Extended"

Then on button click get the selected items from the grid based on the IsSelected binding in the view 然后单击按钮,根据视图中的IsSelected绑定从网格中获取选定的项目。

private void btnDelete_Click(object sender, RoutedEventArgs e) {
    //get selected items
    if (orders.SelectedItems != null && orders.SelectedItems.Count > 0) {
        var toRemove = orders.SelectedItems.Cast<Order>().ToList();
        //Delete logic here
        //...remove items from EF and save

        //Once confirmed remove from items source
        var items = orders.ItemsSource as ObservableCollection<Order>;
        if (items != null) {
            foreach (var order in toRemove) {
                items.Remove(order);       
            } 
        }
    }
}
Write code behind like this....
        public MainWindow()
        {
            InitializeComponent();
            List<Great> p = new List<Great>();
            p.Add(new Great() { Name = "Good" });
            p.Add(new Great() { Name = "Bad" });
            p.Add(new Great() { Name = "Ugly" });
            orders.ItemsSource = p;

        }

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            List<Great> SelectedOrders = new List<Great>();
            for (int i = 0; i < orders.SelectedItems.Count; i++)
            {
                SelectedOrders.Add((Great)orders.SelectedItems[i]);
            }
            var kk = orders.ItemsSource as List<Great>;
            foreach (var item in SelectedOrders)
            {
                kk.Remove(item);
            }
            orders.Items.Refresh();
        }

       public class Great
        {
            public string Name { get; set; }
        }

Just call the Clear() method on the ObservableCollection<Order> : 只需在ObservableCollection<Order>上调用Clear()方法:

private void btnDelete_Click(object sender, RoutedEventArgs e)
{
    var sourceCollection = orders.ItemsSource as ObservableCollection<Order>;
    if (orders != null)
        orders.Clear();
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM