it-swarm.com.ru

Удалить строку в WPF DataGrid

У меня есть таблица данных со значком удаления в виде одного столбца и значок обновления в качестве другого столбца. При нажатии кнопки обновления первая ячейка устанавливается в фокусе.

При нажатии на кнопку «Удалить» я хочу удалить выбранную строку, но я получаю сообщение об ошибке «Операция недопустима, когда используется ItemsSource. Вместо этого открывайте и изменяйте элементы с помощью ItemsControl.ItemsSource». со следующим кодом:

XAML:

<DataGrid Name="grdList" Margin="3,16,0,5" RowHeight="30" ColumnWidth="*"
          ItemsSource="{Binding  List,Mode=TwoWay}" Width="434" 
          AutoGenerateColumns="False" 
          CanUserAddRows="False" AlternatingRowBackground="#FFB9BBFF">
    <DataGrid.Columns>
        <DataGridTextColumn MinWidth="0" Header="Property"
                            Binding="{Binding Path=Property}"/>

        <DataGridTemplateColumn Header="Update"  MinWidth="50" MaxWidth="50">
            <DataGridTemplateColumn.CellStyle>
                <Style TargetType="DataGridCell">
                    <EventSetter Event="PreviewMouseLeftButtonDown"
                                 Handler="EventSetter_OnHandler"/>
                </Style>
            </DataGridTemplateColumn.CellStyle>
            <DataGridTemplateColumn.CellTemplate>
                <DataTemplate>
                    <Image Source="Icons/Update.jpg"/>
                </DataTemplate>
            </DataGridTemplateColumn.CellTemplate>
        </DataGridTemplateColumn>

        <DataGridTemplateColumn Header="Delete"  MinWidth="50" MaxWidth="50">
            <DataGridTemplateColumn.CellStyle>
                <Style TargetType="DataGridCell">
                    <EventSetter Event="PreviewMouseLeftButtonDown"
                                 Handler="EventSetter_OnHandler"/>
                </Style>
            </DataGridTemplateColumn.CellStyle>
            <DataGridTemplateColumn.CellTemplate>
                <DataTemplate>
                    <Image Source="Icons/Delete.jpg"/>
                </DataTemplate>
            </DataGridTemplateColumn.CellTemplate>
        </DataGridTemplateColumn>
    </DataGrid.Columns>
</DataGrid>

C #:

private void EventSetter_OnHandler(object sender, MouseButtonEventArgs e)
{
    object source = e.OriginalSource;
    if (source.GetType() == typeof(Image))
    {
        grdList.IsReadOnly = false;

        selectedRow = FindParent<DataGridRow>(sender as DependencyObject);

        if (((DataGridCell)sender).Column.Header.ToString().ToUpperInvariant() == "DELETE")
        {
            grdList.Items.Remove(selectedRow);
        }
        else
        {
            DataGridCellsPanel panel = FindVisualChild<DataGridCellsPanel>(selectedRow);

            DataGridCell dgc = panel.Children[0] as DataGridCell; 
            dgc.Focus();
            grdList.BeginEdit();

            e.Handled = true;
        }
    }
}

Также Как добавить функцию удаления с помощью клавиши «Удалить» вместе с нажатием на ячейку удаления.

7
user2480288

Я подозреваю, что вDeleteт.е. в EventSetter_OnHandler вы должны удалять элементы изItemsколлекции dataGrid. Что-то вроде этого:

grdList.Items.Remove(someItem);

Но, как ошибка самоочевидна

"Операция недопустима, когда используется ItemsSource. Получите доступ к элементам .__ и измените их с помощью ItemsControl.ItemsSource."

Вы связали ItemsSource с какой-либо коллекцией, поэтому вам нужно удалить элемент из нее. Вы не можете изменять коллекцию Items напрямую при связывании ItemsSource с какой-либо коллекцией . Это должно быть что-то вроде:

List.Remove(someItem);
3
Rohit Vats

Попробуй это,

grdList.Items.RemoveAt(grdList.SelectedIndex);
2
BIBIN K ONANKUNJU

Вы можете привязать SelectedItem вашего DataGrid к свойству. Тогда вы можете позвонить

List.Remove(SelectedDataGridItem);

SelectedDataGridItem - это свойство, к которому привязан Выбранный элемент

1
Tomtom

У меня была такая же проблема, я решил ее так:

 yourrowbindingobject row = (yourrowbindingobject)yourdatagrid.SelectedItems[0];

        ObservableCollection<yourrowbindingobject> data = (ObservableCollection<yourrowbindingobject>)yourdatagrid.ItemsSource;
        data.Remove(row);
0
user3600403