Получить выбранный элемент строки в DataGrid WPF - PullRequest
58 голосов
/ 12 октября 2010

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

Пример DataGrid:

enter image description here

Итак, если я выберу вторую строку, мой MessageBox должен показать что-то вроде: 646 Jim Biology .

Ответы [ 12 ]

125 голосов
/ 12 октября 2010

Вы можете использовать свойство SelectedItem, чтобы получить выбранный в данный момент объект, который затем можно преобразовать в правильный тип. Например, если ваш DataGrid связан с коллекцией Customer объектов, вы можете сделать это:

Customer customer = (Customer)myDataGrid.SelectedItem;

В качестве альтернативы вы можете привязать SelectedItem к вашему исходному классу или ViewModel.

<Grid DataContext="MyViewModel">
    <DataGrid ItemsSource="{Binding Path=Customers}"
              SelectedItem="{Binding Path=SelectedCustomer, Mode=TwoWay}"/>
</Grid>    
17 голосов
/ 12 октября 2010

Если вы используете шаблон MVVM, вы можете связать свойство SelectedRecord вашей виртуальной машины с SelectedItem DataGrid, таким образом у вас всегда будет SelectedValue в вашей виртуальной машине. В противном случае вам следует использовать свойство SelectedIndex DataGrid.

12 голосов
/ 20 апреля 2011
public IEnumerable<DataGridRow> GetDataGridRows(DataGrid grid)
{
    var itemsSource = grid.ItemsSource as IEnumerable;
    if (null == itemsSource) yield return null;
    foreach (var item in itemsSource)
    {
        var row = grid.ItemContainerGenerator.ContainerFromItem(item) as DataGridRow;
        if (null != row) yield return row;
    }
}

private void DataGrid_Details_SelectionChanged(object sender, SelectionChangedEventArgs e)
{
    try
    {           
        var row_list = GetDataGridRows(DataGrid_Details);
        foreach (DataGridRow single_row in row_lis)
        {
            if (single_row.IsSelected == true)
            {
                MessageBox.Show("the row no."+single_row .GetIndex ().ToString ()+ " is selected!");
            }
        }

    }
    catch { }
}
4 голосов
/ 17 декабря 2017

Вы также можете:

DataRowView row = dataGrid.SelectedItem as DataRowView;
MessageBox.Show(row.Row.ItemArray[1].ToString());
4 голосов
/ 25 октября 2014

Это довольно просто в этой DataGrid dg, а класс элементов заполняется в datagrid, а listblock1 - базовый фрейм.

private void DataGrid_SelectionChanged(object sender, SelectionChangedEventArgs e)
    {
        try
        {
            var row_list = (Item)dg.SelectedItem;
            listblock1.Content = "You Selected: " + row_list.FirstName + " " + row_list.LastName;
        }
        catch { }

    }
    public class Item
    {
        public string FirstName { get; set; }
        public string LastName { get; set; }
    }
2 голосов
/ 21 декабря 2012

Хорошо, я поставлю аналогичное решение, которое работает нормально для меня.

 private void DataGrid1_SelectionChanged(object sender, SelectionChangedEventArgs e)
        {
            try
            {
                if (DataGrid1.SelectedItem != null)
                {
                    if (DataGrid1.SelectedItem is YouCustomClass)
                    {
                        var row = (YouCustomClass)DataGrid1.SelectedItem;

                        if (row != null)
                        {
                            // Do something...

                            //  ButtonSaveData.IsEnabled = true;

                            //  LabelName.Content = row.Name;

                        }
                    }
                }
            }
            catch (Exception)
            {
            }
        }
1 голос
/ 21 июля 2015

используйте ваш класс Model для получения значений строк, выбранных из сетки данных, например,

        XDocument xmlDoc = XDocument.Load(filepath);

        if (tablet_DG.SelectedValue == null)
        {
            MessageBox.Show("select any record from list..!", "select atleast one record", MessageBoxButton.OKCancel, MessageBoxImage.Warning);
        }
        else
        {
            try
            {
                string tabletID = "";

                 /*here i have used my model class named as TabletMode*/

                var row_list = (TabletModel)tablet_DG.SelectedItem; 
                 tabletID= row_list.TabletID;

                var items = from item in xmlDoc.Descendants("Tablet")
                            where item.Element("TabletID").Value == tabletID
                            select item;

                foreach (var item in items)
                {
                    item.SetElementValue("Instance",row_list.Instance);
                    item.SetElementValue("Database",row_list.Database);
                }

                xmlDoc.Save(filepath);
                MessageBox.Show("Details Updated..!"
                + Environment.NewLine + "TabletId: " +row_list.TabletID + Environment.NewLine
                + "Instance:" + row_list.Instance + Environment.NewLine + "Database:" + row_list.Database, "", MessageBoxButton.YesNoCancel, MessageBoxImage.Information);
            }

            catch (Exception ex)
            {
                MessageBox.Show(ex.StackTrace);
            }
        }
1 голос
/ 25 февраля 2015

Просто обнаружил это после того, как попробовал ответ Фары, но он не сработал в моем проекте.Просто перетащите столбец из окна Источники данных и перейдите к метке или текстовому блоку.

1 голос
/ 03 апреля 2014
private void Fetching_Record_Grid_MouseDoubleClick_1(object sender, MouseButtonEventArgs e)
{
    IInputElement element = e.MouseDevice.DirectlyOver;
    if (element != null && element is FrameworkElement)
    {
        if (((FrameworkElement)element).Parent is DataGridCell)
        {
            var grid = sender as DataGrid;
            if (grid != null && grid.SelectedItems != null && grid.SelectedItems.Count == 1)
            {
                //var rowView = grid.SelectedItem as DataRowView;
                try
                {
                    Station station = (Station)grid.SelectedItem;
                    id_txt.Text =  station.StationID.Trim() ;
                    description_txt.Text =  station.Description.Trim();
                }
                catch
                {

                }
            }
        }
    }
}
0 голосов
/ 11 февраля 2019

Здесь много ответов, которые, вероятно, работают в определенном контексте, но я просто пытался получить текстовое значение первой ячейки в выбранной строке. Хотя принятый здесь ответ был самым близким для меня, он все же требовал создания типа и преобразования строки в этот тип. Я искал более простое решение, и вот что я придумал:

MessageBox.Show(((DataRowView)DataGrid.SelectedItem).Row[0].ToString());

Это дает мне первый столбец в выбранной строке. Надеюсь, это поможет кому-то еще.

...