彩票走势图

界面控件DevExpress WPF入门级指南:运行时生成的POCO视图模型(二)

翻译|使用教程|编辑:龚雪|2022-04-27 09:59:59.800|阅读 120 次

概述:本文主要介绍DevExpress MVVM架构下生成的POCO视图模型,欢迎下载官方正式版体验!

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

相关链接:

POCO(Plain Old CLR Objects)视图模型简化并加快了开发过程。

POCO 视图模型允许您:

  • 将可绑定属性定义为简单的自动实现的属性。
  • 创建在运行时用作命令的方法。
  • 使属性和方法实现特定于 MVVM 的接口。

这允许您创建干净、简单、可维护和可测试的 MVVM 代码,POCO 视图模型与任何 WPF 控件完全兼容。

您可以使用在编译时生成的视图模型在编译时为您的视图模型生成样板代码。

DevExpress WPF v21.2正式版下载

可绑定属性

POCO 机制为满足以下所有要求的属性生成可绑定属性:

  1. 该属性是公共的并且是自动实现的。
  2. 该属性具有 或 修饰符。
  3. 该属性有一个公共的 getter,以及一个受保护的或公共的 setter。

如果属性没有setter,则可以使用 RaisePropertyChanged 扩展方法显式引发该属性的 PropertyChanged 事件。

您可以定义在属性更改时调用的方法,这些方法名称应使用以下格式:On[PropertyName]Changed 和 On[PropertyName]Changing。

C#


public class LoginViewModel {
public virtual string UserName { get; set; }
protected void OnUserNameChanged() {
//...
}
}

public class LoginViewModel {
public virtual string UserName { get; set; }
protected void OnUserNameChanged(string oldValue) {
//...
}
protected void OnUserNameChanging(string newValue) {
//...
}
}


您可以使用 BindableProperty 属性来:

  • 防止 POCO 机制为指定属性生成可绑定属性;
  • 指定当属性值正在更改或已更改时应调用的方法,当方法的名称与 On[PropertyName]Changed 和 On[PropertyName]Changing 约定不匹配时,这很有用。

C#

public class LoginViewModel {
[BindableProperty(isBindable: false)]
public virtual bool IsEnabled { get; set; }

[BindableProperty(OnPropertyChangedMethodName = "Update")]
public virtual string UserName { get; set; }
protected void Update() {
//...
}
}

您可以使用 Fluent API 来控制 POCO ViewModel 的生成。

C#

[MetadataType(typeof(Metadata))]
public class LoginViewModel {
public class Metadata : IMetadataProvider<LoginViewModel> {
void IMetadataProvider<LoginViewModel>.BuildMetadata
(MetadataBuilder<LoginViewModel> builder) {

builder.Property(x => x.UserName).
OnPropertyChangedCall(x => x.Update());
builder.Property(x => x.IsEnabled).
DoNotMakeBindable();
}
}
public virtual bool IsEnabled { get; set; }
public virtual string UserName { get; set; }
protected void Update() {
//...
}
}

命令

POCO 机制为所有没有参数或单个参数的公共方法生成命令,生成的命令名称遵循 [MethodName]Command 模式,您可以使用 Command 属性或 Fluent API 来控制命令生成机制。

C#

public class LoginViewModel {
[Command(isCommand: false)]
public void SaveCore() {
//...
}

[Command(CanExecuteMethodName = "CanSaveAccountSettings",
Name = "SaveCommand",
UseCommandManager = true)]
public void SaveAccountSettings(string fileName) {
//...
}
public bool CanSaveAccountSettings(string fileName) {
return !string.IsNullOrEmpty(fileName);
}
}

[MetadataType(typeof(Metadata))]
public class LoginViewModel {
public class Metadata : IMetadataProvider<LoginViewModel> {
void IMetadataProvider<LoginViewModel>.BuildMetadata(MetadataBuilder<LoginViewModel> builder) {
builder.CommandFromMethod(x => x.SaveCore()).
DoNotCreateCommand();
builder.CommandFromMethod(x => x.SaveAccountSettings(default(string))).
CanExecuteMethod(x => x.CanSaveAccountSettings(default(string))).
CommandName("SaveCommand");
}
}
public void SaveCore() {
//...
}
public void SaveAccountSettings(string fileName) {
//...
}
public bool CanSaveAccountSettings(string fileName) {
return !string.IsNullOrEmpty(fileName);
}
}

要更新 POCO 视图模型中自动生成的命令,请使用 DevExpress.Mvvm.POCO.POCOViewModelExtensions 类中提供的 RaiseCanExecuteChanged 扩展方法。

C#

[POCOViewModel]
public class ViewModel {
public void GoBack(){
//...
}
public bool CanGoBack(){
//...
}
public void UpdateSaveCommand(){
this.RaiseCanExecuteChanged(c => c.GoBack());
}
}

DevExpress WPF | 下载试用

DevExpress WPF拥有120+个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件的衍伸产品,还是以数据为中心的商业智能产品,都能通过DevExpress WPF控件来实现。


DevExpress技术交流群6:600715373      欢迎一起进群讨论

慧都图表线上公开课火热报名中

标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn

文章转载自:慧都网

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP