我正在尝试显示与外键链接的两个sql ce 3.5 sp1数据库表中的数据-客户和订单。当在 datadrig 中选择客户时,我希望用订单填充另一个网格。
我正在使用查询:

var profiles = from c in db.Customers.Include("Orders")
                           select c;

在我的 ViewModel 中:
private Models.Customers _selecteditem;
        public Models.Customers SelectedItem
        {
            get { return _selecteditem; }

        }

View 如下所示:
<Grid>
        <toolkit:DataGrid  x:Name="dg1" ItemsSource="{Binding Customers}" SelectedItem="{Binding SelectedItem, mode=TwoWay}">
            </toolkit:DataGrid>
        <toolkit:DataGrid  x:Name="dg2" ItemsSource="{Binding Path=SelectedItem.Orders}">
        </toolkit:DataGrid>
    </Grid>

我得到的错误是:
Warning 1   Field 'Clients.ViewModels.CustomerViewModel._selecteditem' is never assigned to, and will always have its default value null

如何使其正常工作?当我只想显示客户时,没关系。
感谢您的任何建议。

最佳答案

你需要一个 SelectedItem 的 setter

private Models.Customers _selecteditem;
public Models.Customers SelectedItem
{
    get { return _selecteditem; }
    set { _selectedItem = value; }
}

此外,由于您在绑定(bind)中使用它,您会希望 ViewModel 实现 INotifyPropertyChanged 所以它实际上是:
private Models.Customers _selecteditem;
public Models.Customers SelectedItem
{
    get { return _selecteditem; }
    set
    {
      if (_selectedItem != value)
      {
        _selectedItem = value;
        NotifyPropertyChanged("SelectedItem");
      }
    }
}

public event PropertyChangedEventHandler PropertyChanged;

private void NotifyPropertyChanged(String info)
{
    if (PropertyChanged != null)
    {
        PropertyChanged(this, new PropertyChangedEventArgs(info));
    }
}

关于WPF SelectedItem 在 MVVM 中不起作用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2865225/

10-13 08:16