这是我的第一个WPF应用程序,我需要一些帮助
我创建了一个WPF窗口,其中包含使用EF绑定到数据库的Datagrid,CollectionViewSource
当从窗口上的数据源窗口拖放表时,MDI自动生成代码
ObjectQuery<ITPORTAL.HRMS_IT_ASSET_MASTER> ass = gRACHRMSEntities.HRMS_IT_ASSET_MASTER;
分配给CollectionViewSource.Source的对象查询如下
hRMS_IT_ASSET_MASTERQuery = Load_Asset_Master_Data(gRACHRMSEntities.HRMS_IT_ASSET_MASTER);
hRMS_IT_ASSET_MASTERViewSource.Source = hRMS_IT_ASSET_MASTERQuery.Execute(System.Data.Objects.MergeOption.AppendOnly);
但是这段代码不支持Filtering Facility,这就是为什么我要添加像这样的东西
private ObservableCollection<ITPORTAL.HRMS_IT_ASSET_MASTER> Load_Asset_Master_Data(System.Data.Objects.ObjectQuery<ITPORTAL.HRMS_IT_ASSET_MASTER> objectSet)
{
ObservableCollection<ITPORTAL.HRMS_IT_ASSET_MASTER> oc = null;
try
{
var value = from Asset_Master in objectSet
where Asset_Master.IT_ASSET_IS_ACTIVE == "1" && Asset_Master.IT_ASSET_IS_SCRAPED == "0" && Asset_Master.IT_ASSET_IS_SCRAP_FINAL == "0"
select Asset_Master;
oc = new ObservableCollection<HRMS_IT_ASSET_MASTER>(value.ToList());
}
catch (Exception err)
{
MessageBox.Show(err.Message, "IT Portal Error", MessageBoxButton.OK, MessageBoxImage.Error, MessageBoxResult.OK);
}
return oc;
}
并分配给CollectionViewSource,如下所示
hRMS_IT_ASSET_MASTERViewSource.Source = Load_Asset_Master_Data(gRACHRMSEntities.HRMS_IT_ASSET_MASTER);
通过这种方式,我可以做过滤 但我失去了一个功能,因为 当我在数据网格的末尾填充行并按保存 Save命令不考虑添加的行, save命令仅响应编辑操作 这是Save事件处理程序
private void btnSave_Click(object sender, RoutedEventArgs e)
{
try
{
if (gRACHRMSEntities.SaveChanges() > 0)
{
txtblkStatus.Text = "Changes has been saved.";
}
}
catch (Exception err)
{
MessageBox.Show(err.Message, "Error", MessageBoxButton.OK, MessageBoxImage.Error, MessageBoxResult.OK);
} }
我在网上查了一下,发现了
使用ObservableCollection<T>
时,我必须为{。{1}}为T。提供我自己的实现
答案 0 :(得分:0)
我认为你应该写
hRMS_IT_ASSET_MASTERViewSource.ItemsSource =Load_Asset_Mast ...
而不是:
hRMS_IT_ASSET_MASTERViewSource.Source =Load_Asset_Mast ...
我的意思是你应该设置ItemsSource。