2
votes

I would like to get all rows in order to check some rows that are the same in the database , I'm try using many solutions in StackOverlow but any of them work for me :

for (int i = 0; i < dataGrid.Items.Count; i++)
{
    DataGridRow row = (DataGridRow)dataGrid.ItemContainerGenerator
                                               .ContainerFromIndex(i);
}

This code return value cannot be null Exception.

I have tried also this line of code and I'm got the same Exception ( the object currentitem was null ).

var currentItem = myDataGrid.SelectedItem as MyObject;

Complete Code:

  private void UserControl_Loaded(object sender, RoutedEventArgs e)
     {

        grid.ItemsSource = null;
        grid.ItemsSource = work;
        grid.Items.Refresh();

        for (int i = 0; i < grid.Items.Count; i++) // My grid items count equals to 7
        {
          
            DataGridRow row = (DataGridRow)grid.ItemContainerGenerator.ContainerFromIndex(i); // this value was null 
            var currentItem = grid.SelectedItem as object; // this value was null


        }

    }
2

2 Answers

0
votes

You could bind the item source of your DataGrid to an ObservableCollection and run a foreach loop over it.

I think that makes things a lot easier.

-1
votes

Finally I got it , I fixed the error by using this code :

 for (int i = 0; i < grid.Items.Count; i++)
            {
                GridModel row = (GridModel)grid.Items[i];
            }
// Note : The grid model is a class for the Datagrid ( properties are the same as the columns name of the datagrid