[英]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.