界面控件DevExpress WinForms MVVM使用教程(二):创建主、详细视图

在上文中,Scaffolding Wizard 为您创建了ViewModel,现在您需要创建与这些ViewModel相关的视图。

主视图

主应用程序视图是您的主要应用程序表单。 要构建其内容,请删除任何适当的内容容器(NavigationFrame, DocumentManager, XtraTabControl等)和包含打开模块按钮的 RibbonControl 。

提示:所选内容容器的类型将影响您以后需要使用的服务。 如果您根本不删除任何内容容器,将需要使用 WindowedDocumentManagerService 并且所有模块都将作为单独的表单打开。

例如您选择了文档管理器,在这种情况下,您的主视图将如下所示。

界面控件DevExpress WinForms MVVM使用教程(一):创建向导

将所有功能区项目保留为fakes – 您将在下一步中提供它们的功能。

最后,将 MvvmContext 组件拖放到表单上,并在其智能标记中选择与此视图关联的主视图模型。 由 Scaffolding Wizard 生成的主 ViewModel 将被称为 <Your_DbContext_Name>ViewModel

详细视图

上一步中生成的Account、Transaction 和 Category 实体的 ViewModel 已经具有基本功能 – 创建新记录、添加和删除现有记录等,现在为这些 ViewModel 中的每一个创建一个相关的视图。

1. 添加一个新的 Views 解决方案文件夹,其中包含三个子文件夹:Account、Category 和 Transaction。 为每个文件夹放置一个新的 UserControl – 这些将是您的详细视图(参见下图)。

界面控件DevExpress WinForms MVVM使用教程(一):创建向导

2. 打开 AccountView 用户控件并创建一个简单的 UI – 显示帐户的 GridControl 和执行简单操作(添加、创建、修改和删除帐户)的 RibbonControl,可以得到这样的结果:

界面控件DevExpress WinForms MVVM使用教程(一):创建向导

3. 与主视图类似,将 MvvmContext 组件拖放到用户控件上,并将 AccountCollectionViewModel 设置为相关的 ViewModel。

界面控件DevExpress WinForms MVVM使用教程(一):创建向导

界面控件DevExpress WinForms MVVM使用教程(一):创建向导

C#

[Display(AutoGenerateField = false)]public void Close() {if(DocumentOwner != null)DocumentOwner.Close(this);}

VB.NET

<Display(AutoGenerateField := False)>Public Sub Close()If DocumentOwner IsNot Nothing ThenDocumentOwner.Close(Me)End IfEnd Sub

进一步的 CollectionViewModel 检查将显示一些命令,如‘Edit’和‘Delete’,后面跟着相应的布尔值“Can…”属性。 在 POCO ViewModels 中,此类属性充当 CanExecute 条件,指定相关命令当前是否可用,因此绑定到该命令的 UI 元素当前是否启用。

C#

public bool CanEdit(TProjection projectionEntity) {return projectionEntity != null && !IsLoading;}

VB.NET

Public Function CanEdit(ByVal projectionEntity As TProjection) As BooleanReturn projectionEntity IsNot Nothing AndAlso Not IsLoadingEnd Function

这是一种合理的方法,因为如果当前没有选择集合对象(例如,特定交易),您将无法单击‘Edit’等按钮。 这意味着 Scaffolding Wizard 也会处理这些细节,您无需手动实现此逻辑。

6. 重复前面的步骤,为 CategoriesCollection 和 TransactionsCollection ViewModels 创建类似的详细视图。

DevExpress WinForm | 下载试用

DevExpress WinForm拥有180+组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!

更多产品正版授权详情及优惠,欢迎咨询在线客服>>


DevExpress技术交流群5:742234706      欢迎一起进群讨论

DevExpress企业定制服务
标签:

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2022年1月6日
下一篇 2022年1月6日

相关推荐

发表回复

登录后才能评论