如何解决涉及在ViewModel或Model中处理数据来自DB的逻辑?
| 我正在使用WPF开发应用程序。我使用的模式显然是MVVM。另外,我正在使用Entity Framework ORM和LINQ-to-Entities查询EF对象。 我对MVVM的理解是,视图应该没有代码隐藏,而对ViewModel的了解应该是ViewModel包含与View绑定的某些属性,并且还包含用于处理视图事件的命令。而模型仅包含从DB获取数据的代码。 在我的模型类中,我刚刚编写了使用Linq-to-entity直接查询EF对象的函数。在将数据分配给VM中的属性之前,我需要对数据执行的处理是存在于VM中或存在于VM项目中的类中。仅在这里提到,我有3个项目-View,ViewModel和Model。 我的问题是,我可以将那些功能(涉及对来自DB的数据的处理)保留在VM项目中还是应该保留在Model项目中?如果在ViewModel项目中,它应该在相关的VM中还是在VM项目中存在的单独类中?解决方法
一种常用的做法是将业务逻辑委托给服务层,并使用存储库模式执行业务逻辑。如其他答案所述,ViewModel应该使用视图特定的属性和处理UI交互的命令来装饰模型。通过其自身的定义,模型应具有用于处理数据的所有逻辑。
如果您遵循面向服务的体系结构,则可以向ViewModel注入服务。该服务负责执行业务功能。这些业务功能大部分是在持久数据上完成的。可以使用任何ORM工具和技术(例如EF或NHibernate)很好地抽象该逻辑。您可以在Google上搜索“存储库模式”,如果您遵循此架构,这可能会有所帮助。
如果不需要,则不必使用存储库模式。您仍然可以直接从服务层使用EF。拥有存储库的优点是,它在持久性层(数据库)和域层(模型)之间的作用就像映射器。
希望这可以帮助。
,它们应该在Model项目中,ViewModel只是View期望的一种表示形式,仅此而已。
,职责是:
模型->从数据库,服务等获取数据,并通过域对象公开数据。不关心数据将如何显示。只关心涉及域对象的业务逻辑。
ViewModel->从模型读取数据并装饰它们,以便它们可以以正确的格式显示在View中。公开视图可以绑定以获取数据的属性。还公开视图可以在用户输入上调用的命令。
查看->根据通过DataBinding从VM接收的数据,使用漂亮的DataTemplate或UserControl显示数据。绑定到VM命令以调用用户输入。
理想情况下,ViewModel仅与在UI上显示数据有关,而与修改模型无关。它在其构造函数中接收一个模型对象,并通过数据绑定公开供视图使用的属性。该模型不知道ViewModel。每当模型数据发生更改时,就可以通过VM预订的模型引发的事件来通知ViewModel更改。否则,只要视图调用VM中的属性getter获取数据,VM便必须查询模型。
无论如何显示模型,模型都应公开其属性。因此,不应对属性进行任何处理。 ViewModel可以根据View的要求修饰从Model接收的数据。
,我认为最好将数据库处理功能移至Model项目,因为ViewModel可能承担过多责任。
我将尝试显示一个示例:
假设我们有一个类
SomeViewModel
,其属性为IsHighlited
和Item
,如下所示:
class SomeViewModel
{
public bool IsHighlighted
{
get
{
/* View logic here */
}
}
public SomeClass Item
{
get
{
/* Retreiveing an item from database */
}
}
}
现在,当您需要修改视图逻辑时,您必须修改SomeViewModel
类(没关系),但是当您需要修改数据库通信逻辑时,您还需要修改同一类,但这还不太好。
单一责任原则说:
决不能再有一个
班级变更的原因。
结果,如果您保持现在的状态,将来可能会遇到不必要的代码复杂性。
,您可能对WPF应用程序框架(WAF)的BookLibrary示例应用程序感兴趣。它显示了如何将实体框架与MVVM模式一起使用。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。