WPF C # Заполнение данных в комбинированный список из отдельного файла класса - PullRequest
0 голосов
/ 04 сентября 2018

У меня есть три файла, которые заполняют данные из базы данных и присваивают их представлениям xaml.

Это мой файл user.cs, который содержит функции пользователя:

public List<User> getUserList()
    {
        var user = new List<User>();
        string query;
        query = "select * from users";
        da = new MySqlDataAdapter(query, db.GetConnection());
        da.Fill(dt);
        reader = db.QueryCommand(query);
        ComboBox cb = new ComboBox();
        while (reader.Read())
        {
            user.Add(new User()
            {
                UserId = reader[0].ToString(),
                UserName = reader[1].ToString(),
                UserCreatedDate = reader[5].ToString(),
                UserEmail = reader[6].ToString(),
                UserFirstName = reader[7].ToString(),
                UserLastName = reader[8].ToString(),
                UserRole = reader[3].ToString()

            });
        }
        reader.Close();

        return user;

    }

Это мой файл viewusers.cs:

private void btnUpdate_Click(object sender, RoutedEventArgs e)
    {
        TextBox txtFirstName = (TextBox)GetChildren(userDataGrid).First(x => x.Name == "txtFirstName");
        TextBlock txtBlockId = (TextBlock)GetChildren(userDataGrid).First(x => x.Name == "txtBlockId");
        ComboBox cbUserRole = (ComboBox)GetChildren(userDataGrid).First(x => x.Name == "cbUserRole");
        string firstName = txtFirstName.Text;
        string id = txtBlockId.Text;
        string userRole = cbUserRole.SelectedItem.ToString();
    }

Это мой файл viewusers.xaml:

  <DataGrid.RowDetailsTemplate>
            <DataTemplate>
                <Border BorderThickness="0" Background="BlanchedAlmond" Padding="10">
                    <StackPanel Orientation="Horizontal">
                        <StackPanel Orientation="Horizontal">
                            <TextBlock FontSize="12" Text="User Role: " VerticalAlignment="Center" />
                            <ComboBox x:Name="cbUserRole" FontSize="16" Foreground="MidnightBlue" Text="{Binding UserRole}" VerticalAlignment="Center" />
                        </StackPanel>
                        <StackPanel>
                            <Button x:Name="btnUpdate" Content="Update" VerticalAlignment="Center" HorizontalAlignment="Right" Click="btnUpdate_Click"/>
                        </StackPanel>
                    </StackPanel>
                </Border>
            </DataTemplate>
        </DataGrid.RowDetailsTemplate>

Теперь проблема в том, что я не могу заполнить пользовательские роли в выпадающем списке. Как я могу решить эту проблему? Поскольку выпадающий список отсутствует в файле представлений, я не могу найти этот выпадающий список из файла пользовательского класса.

1 Ответ

0 голосов
/ 04 сентября 2018

Для MVVM Pattern я отправил свой код. Я надеюсь, что это может работать для вас.

.xaml просмотреть файл:

 <Grid Style="{DynamicResource Dropdown_grid}" Grid.Column="0" Grid.Row="1">
                                        <StackPanel Grid.Column="0" HorizontalAlignment="Left" Style="{DynamicResource Dropdown_stakpanel}">
                                            <TextBlock HorizontalAlignment="Left" Name="FeesGroup" TextWrapping="Wrap" FontWeight="Bold" Text="Select Fees Group *" VerticalAlignment="Top"/>
                                            <ComboBox x:Name="drpfeesgroup" MinHeight="30" HorizontalAlignment="Left" Background="Black" SelectedValuePath="Tag" Tag="{Binding id}" MinWidth="200" ItemsSource="{Binding Path=Persons}" SelectedItem="{Binding Path=SPerson}">
                                            </ComboBox>
                                        </StackPanel>
                                    </Grid>

.xaml.cs Код файла: вызовите конструктор, если хотите отобразить событие загрузки страницы.

 var ds = feesMaster_ViewModel.Dropdown_Feesgroup();
        if (ds.Tables[0].Rows.Count > 0)
        {
            drpfeesgroup.ItemsSource = ds.Tables[0].DefaultView;
            drpfeesgroup.DisplayMemberPath = ds.Tables[0].Columns["name"].ToString();
            drpfeesgroup.SelectedValuePath = ds.Tables[0].Columns["id"].ToString();
        }

feeMaster_ViewModel.ViewModel.cs Файл: (Создать метод для сетки данных связывания)

public DataSet Dropdown_Feesgroup()
    {
        var ds1 = new DataSet();
        using (con = new MySqlConnection(ConfigurationManager.ConnectionStrings["schoolmanagment_connectionString"].ToString()))
        {
            try
            {
                con.Open();
                cmd = new MySqlCommand("select id,name from fee_groups", con);
                da = new MySqlDataAdapter(cmd);
                ds = new DataSet();
                da.Fill(ds, "fee_groups");
                if (ds.Tables[0].Rows.Count > 0)
                {
                    ds1 = ds;
                }

            }
            catch (Exception ex)
            {
                var a = ex.ToString();
                throw;
            }
            finally { con.Close(); }
            return ds;
        }

    }

Надеюсь, My This Code поможет вам решить вашу проблему. Я постараюсь сделать все возможное, чтобы дать решение вашего вопроса.

...