簡體   English   中英

如何將數據從數據網格顯示到單選按鈕?

[英]How to display data from datagrid to radio button?

所以我是 WPF 的新手,我希望當我單擊 DataGrid 時,RadioButton 將顯示與 DataGrid 中相同的數據。

對不起,我的英語不好。

代碼 #

private void DataGrid_SelectionChanged(object sender, SelectionChangedEventArgs e)
{
  DataGrid datagrid = (DataGrid)sender;
  DataRowView row_selected = datagrid.SelectedItem as DataRowView;

  if (row_selected != null)
  {
    Name_txt.Text = row_selected["Name"].ToString();
    Age_txt.Text = row_selected["Age"].ToString();
    Address_txt.Text = row_selected["Address"].ToString();
    if (rbMale.IsChecked == true)
    {
      row_selected["Gender"].ToString();
    }
    else
    {
      row_selected["Gender"].ToString();
    }
  }
}

希望這可以幫助。

我是 WPF 的新手,希望能得到一些簡單的答案。

這是一個非常簡單的代碼:

XAML

<Window x:Class="RadioButtonDataGridTest.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:RadioButtonDataGridTest"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800"
        Loaded="OnLoaded">
    <Grid>
        <StackPanel>
            <DataGrid ItemsSource="{Binding People}" AutoGenerateColumns="False" SelectionChanged="DataGrid_SelectionChanged">
                <DataGrid.Columns>
                    <DataGridTextColumn Header="Name" Binding="{Binding Name}" />
                    <DataGridTextColumn Header="Age" Binding="{Binding Age}" />
                    <DataGridTextColumn Header="Address" Binding="{Binding Address}" />
                    <DataGridTextColumn Header="Gender" Binding="{Binding Gender}" />
                </DataGrid.Columns>
            </DataGrid>

            <Label FontWeight="Bold" Content="Name" Margin="0,10,0,0"/>
            <TextBox x:Name="Name_txt" />

            <Label FontWeight="Bold" Margin="0,10,0,0">Male or female?</Label>
            <RadioButton GroupName="sex" Name="rbMale">Male</RadioButton>
            <RadioButton GroupName="sex" Name="rbFemale">Female</RadioButton>
        </StackPanel>
    </Grid>
</Window>

代碼隱藏
如您所願,當DataGrid選擇更改時選擇RadioButton

public partial class MainWindow : Window
{
    private ObservableCollection<Person> people;

    public MainWindow()
    {
        InitializeComponent();
        DataContext = this;
        people = new ObservableCollection<Person>();
    }

    public ObservableCollection<Person> People { get { return people; } }

    private void OnLoaded(object sender, RoutedEventArgs e)
    {
        people.Clear();
        people.Add(new Person() { Name="John", Age=12, Address="John address", Gender="Male"});
        people.Add(new Person() { Name = "Mary", Age = 23, Address = "Mary address", Gender = "Female" });
    }

    private void DataGrid_SelectionChanged(object sender, SelectionChangedEventArgs e)
    {
        Person person = null;
        DataGrid datagrid = (DataGrid)sender;

        if (datagrid == null || datagrid.SelectedItems.Count != 1) return;
        
        person = datagrid.SelectedItem as Person;
        
        if (person != null)
        {
            Name_txt.Text = person.Name;
            //Age_txt.Text = row_selected["Age"].ToString();
            //Address_txt.Text = row_selected["Address"].ToString();
            if (person.Gender == "Male") rbMale.IsChecked = true;
            else if (person.Gender == "Female") rbFemale.IsChecked = true;
        }
    }
}

我可以建議您使用 Enum 或 integer(字節)值來管理性別而不是比較字符串嗎?

model

public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
    public string Address { get; set; }
    public string Gender { get; set; }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM