Avalonia按钮启用状态由绑定命令的CanExecute方法控制,推荐使用自动响应的ReactiveCommand;手动实现ICommand时须主动触发CanExecuteChanged事件,并确保绑定正确。

在 Avalonia 中,按钮的启用/禁用状态由绑定命令的 CanExecute 方法控制。只要命令实现了 ICommand 接口并正确返回布尔值,Avalonia 就会自动响应其变化,更新按钮的 IsEnabled 状态。
确保命令实现 ICommand 并支持 CanExecute
Avalonia 不强制要求命令必须继承某个基类,但需满足 ICommand 合约。推荐使用 ReactiveCommand(来自 ReactiveUI)或手动实现 ICommand。关键点:
-
CanExecute(object? parameter)必须返回当前是否允许执行的逻辑结果(如:输入非空、数据已加载、无正在进行的操作) - 当影响
CanExecute的状态改变时(例如文本框内容更新),必须调用CanExecuteChanged事件通知 UI 重新查询 - 若使用
ReactiveCommand,它会自动监听源 Observable(如WhenAnyValue),无需手动触发事件
使用 ReactiveCommand(推荐,自动响应)
在 ViewModel 中定义命令时,用 ReactiveCommand.Create 并传入 canExecute 条件流:
// ViewModel 构造函数中
this.WhenAnyValue(x => x.UserName, x => x.Password)
.Select(x => !string.IsNullOrWhiteSpace(x.Item1) && x.Item2?.Length >= 6)
.ToProperty(this, x => x.CanLogin, out _canLogin);
<p>LoginCommand = ReactiveCommand.Create(OnLogin, CanLogin);
登录后复制
此时按钮绑定后会自动启用/禁用:
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~