我正在WPF中的项目上工作,使用本地数据库(通过SQL Express)和Entity Framework作为ORM。
我想实现与 View 类一样多的ViewModel 。一种1 对 1的关系,我听说这是实现MVVM的好方法(如果您不同意,请分享原因)。我对此的看法是,每个ViewModel都服务于它的View (即共享模型层提供的数据库中的一些数据)。
所以每个View都有它的ViewModel,它是一种仆人。;)
在实现这个概念的过程中,我遇到了这个问题......假设至少有 2 个ViewModel想要获取存储在数据库中的所有客户的最新列表。
在这种情况下我会怎么做?我必须将此代码添加到所有这些ViewModel(针对DRY):
public ObservableCollection<Customer> Customers;
private ObservableCollection<Customer> GetAllCustomers()
{
var oc = new ObservableCollection<Customer>();
using (var db = new MyDbContext())
{
var query = from b in db.Customers
orderby b.Surname
select b;
foreach (var customer in query)
{
oc.Add(customer);
}
}
return oc;
}
或者(或者)我会FooClass
用我上面写的相同的代码做一些静态的,但是作为静态的。这不是很聪明,因为FooClass
一段时间后这样的事情会变得一团糟。
我找不到任何更聪明的解决方案。我相信你知道我应该如何巧妙地编写代码。所以请帮助我。我应该如何为许多ViewModel提供相同的功能?