我正在尝试显示与外键链接的两个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/