WinForms MVVM使用教程(二):创建主、详细视图

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

获取工具下载 - DevExpress v21.2

主视图

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

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

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

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

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

详细视图

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

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

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

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

重要提示:Scaffolding Wizard 将为每个表生成两个 ViewModel,存储在 DbContext 中。 例如,对于 Transactions 表,它将生成 TransactionsViewModel 和 TransactionsCollectionViewModel。 第一个 ViewModel 设计用于处理单个事务对象,适用于稍后创建的编辑表单;第二个 ViewModel 与整个交易集合一起使用,应该在详细视图中使用。

4. 现在您需要将项目添加到您的 RibbonControl,与主 ViewModel 不同,在这里您可以自动生成项目。 您自动生成的 AccountCollectionViewModel 派生自父 CollectionViewModel,它声明了使用集合的基本方法 - 添加新对象、刷新集合、编辑当前对象等,此功能位于命令中。MvvmContext 组件能够从 ViewModel 检索命令并将相应的按钮添加到 RibbonControl,为此,请调用组件智能标签并单击 ‘Retrieve Commands’链接。

这将检索四个命令 - 新建、编辑、刷新和删除,将为它们中的每一个创建一个相应的 RibbonControl 项。 重建解决方案,这些自动生成的项目将自动从图像库和上下文相关图像接收适当的图像。

 

 

 5. 如果您检查 CollectionViewModel,将看到此 ViewModel 声明的命令比添加到功能区控件的这四个命令还多。 未添加所有剩余命令的原因是因为它们标有特定的显示Data Annotation Attribute,该属性从命令编辑器中“隐藏”了此命令。

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

要为编辑器 ‘open’ 此命令,请将 false 替换为 true 或简单地删除整个属性。 当您这样做时, ‘Close’ 命令应出现在命令编辑器中,您将能够为其生成功能区项目。

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

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

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

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

文章转载自:DevExpress控件中文网 [https://www.devexpresscn.com/]

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值