0

シンプルなMVVMフレームワークを使用してシンプルなSilverlight4.0LOBアプリケーションを作成します。

のすべての従業員のリストを表示する従業員リストビューがあり、EmployeeListViewModelに次のようないくつかのプロパティがあります。

    private Grade selectedGrade;
    public Grade SelectedGrade
    {
        get { return selectedGrade; }
        set
        {
            selectedGrade = value;
            NotifyPropertyChanged(m => m.SelectedGrade);
        }
    }

    private Religion selectedReligion;
    public Religion SelectedReligion
    {
        get { return selectedReligion; }
        set
        {
            selectedReligion = value;
            NotifyPropertyChanged(m => m.SelectedReligion);
        }
    }
    private ObservableCollection<Grade> grades;
    public ObservableCollection<Grade> Grades
    {
        get { return grades; }
        set
        {
            grades = value;
            NotifyPropertyChanged(m => m.Grades);
        }
    }

    private ObservableCollection<Religion> religions;
    public ObservableCollection<Religion> Religions
    {
        get { return religions; }
        set
        {
            religions = value;
            NotifyPropertyChanged(m => m.Religions);
        }
    }
    private ObservableCollection<Department> departments;
    public ObservableCollection<Department> Departments
    {
        get { return departments; }
        set
        {
            departments = value;
            NotifyPropertyChanged(m => m.Departments);
        }
    }
    private Employee selectedEmployee;
    public Employee SelectedEmployee
    {
        get { return selectedEmployee; }
        set
        {
            selectedEmployee = value;
            SetCanProperties();
            NotifyPropertyChanged(m => m.SelectedEmployee);
        }
    }
    private ObservableCollection<Employee> employees;   
    public ObservableCollection<Employee> Employees
    {
        get { return employees; }
        set
        {
            employees = value;
            NotifyPropertyChanged(m => m.Employees);
        }
    }
    private Department selectedDepartment;
    public Department SelectedDepartment
    {
        get { return selectedDepartment; }
        set
        {
            selectedDepartment = value;
            NotifyPropertyChanged(m => m.SelectedDepartment);
        }
    }

これで、私のビューには、従業員リストで選択した従業員を編集するためのボタンがあり、編集するEmployeeDetailsを含む新しい子ウィンドウが開きます。

  EmployeeListViewModel viewModel;
    public EmployeeListView()
    {
        InitializeComponent();
        viewModel = (EmployeeListViewModel)DataContext;
    }

これが従業員の編集方法です

 private void editItemButton_Click(object sender, RoutedEventArgs e)
    {
        // Exit if no product selected
        if (viewModel.SelectedEmployee == null) return;

        // Create a product detail model
       EmployeeDetailViewModel detailModel =
            new  EmployeeDetailViewModel(viewModel.SelectedEmployee);
        // set comboboxes !! 

       detailModel.Departments = viewModel.Departments;
       detailModel.Religions = viewModel.Religions;

       detailModel.Grades = viewModel.Grades;

        // Start editing
        detailModel.BeginEdit();

        // Show EmployeeDetail view
       EmployeeDetailView itemDetail = new  EmployeeDetailView(detailModel);
        itemDetail.Closed += (s, ea) =>
        {
            if (itemDetail.DialogResult == true)
            {
                // Confirm changes

                detailModel.EndEdit();
            }
            else
            {
                // Reject changes
                detailModel.CancelEdit();
            }
        };
        itemDetail.Show();
    }

今私の詳細にチャイルドビュー私はこの請負業者を持っています

   public EmployeeDetailView(EmployeeDetailViewModel viewModel)
    {
        InitializeComponent();
        DataContext = viewModel;
    }

これが私のDetailsViewModel請負業者です

   public EmployeeDetailViewModel(Employee model)
    {
        base.Model = model;
    }
         private ObservableCollection<Religion> religions;
    public ObservableCollection<Religion> Religions
    {
        get { return religions; }
        set
        {
            religions = value;
            NotifyPropertyChanged(m => m.Religions);
        }
    }

    private ObservableCollection<Grade> grades;
    public ObservableCollection<Grade> Grades
    {
        get { return grades; }
        set
        {
            grades = value;
            NotifyPropertyChanged(m => m.Grades);
        }
    }
    private ObservableCollection<Department> departments;
    public ObservableCollection<Department> Departments
    {
        get { return departments; }
        set
        {
            departments = value;
            NotifyPropertyChanged(m => m.Departments);
        }
    }

結局、これでバインディングができました。部門、宗教、学年用の3つのコンボボックスがあります(これは私の従業員テーブルの外部キーです)

 <ComboBox  ItemsSource="{Binding Departments}" DisplayMemberPath="DepartmentName" SelectedValue="{Binding Model.Emp_Department, Mode=TwoWay}" SelectedValuePath="DepartmentId"/>
   <ComboBox  ItemsSource="{Binding Grades}" DisplayMemberPath="GradeName" SelectedValue="{Binding Model.Emp_Grade, Mode=TwoWay}" SelectedValuePath="GradeId"/>

など..問題は、値を変更したときに、Departmentsコンボボックスのみがソース値を更新していることです。

バインディングステートメントがまったく同じであっても、他のコンボボックスは..しません!!

たくさん書いたことをお詫びします..しかし、誰かがこれで私を助けることができますか?

どうもありがとう

4

2 に答える 2

0

ここに私がコンボを行う方法があります:

 <ComboBox ItemsSource="{Binding Path=ListPeople, UpdateSourceTrigger= PropertyChanged}" SelectedItem="{Binding Path=SelectedPerson, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" DisplayMemberPath="FirstName"/>

そして私のビューモデルで:

 private ObservableCollection<Person> listPeople = new ObservableCollection<Person>();

 public IEnumerable<Person> ListPeople
     {
         get { return this.listPeople; }
     }

 public Person SelectedPerson
     {
         get { return selectedPerson; }
         set
         {
             selectedPerson = value;
             if (selectedPerson != null)
             {
                 NextToPayID = selectedPerson.PersonID;
             }
             base.RaisePropertyChanged("SelectedPerson");
         }
     }

あなたがそれを助けることができるかどうか見てください!

于 2011-11-14T11:18:44.980 に答える
0

残念ながら、ビューから基礎となるモデルに直接バインドしているため(ビューモデルのビジネスロジック/検証を意味する)、MVVMの分離は少し混乱しています。

ただし、すべてが整っているように見えるので、次のことをお勧めします。

Xaml を次のように変更します (SelectedValue から SelectedItem への変更に注意してください)。

<ComboBox  ItemsSource="{Binding Departments}" DisplayMemberPath="DepartmentName" SelectedItem="{Binding SelectedDepartment, Mode=TwoWay}"/>
<ComboBox  ItemsSource="{Binding Grades}" DisplayMemberPath="GradeName" SelectedItem="{Binding SelectedGrade, Mode=TwoWay}"/>

次に、SelectedDepartment/SelectedGrade プロパティのセッター内で、必要な検証を実行し、選択した項目の Id を (詳細) モデルのプロパティに書き込みます。

それが役に立てば幸い。

于 2011-10-12T16:21:14.383 に答える