对于WPF ICommand,事件处理程序-=的等效值是什么?
我们有一个用户控制按钮,它管理提交购买请求的功能,但要求用户首先在工作站上注册。
WinForms的用法是:
this.Click -= this.btnRegister_Click;
this.Click -= this.btnSubmit_Click;WPF中的现代化版本只有一个ICommand属性和典型的声明。
public ICommand ClickCommand { get; set; }
....
ClickCommand = new DelegateCommand(RegisterClicked);一旦用户注册,用户控件将重新初始化到提交进程。存在一个检查按钮状态的简单触发器。从视觉上看,触发器工作得很好,这表明程序正在处理初始化代码块。
<Label.Style>
<Style TargetType="Label" BasedOn="{StaticResource ButtonLabel}">
<Setter Property="Content" Value="Approvals"/>
<Style.Triggers>
<DataTrigger Binding="{Binding Path=ButtonState}" Value="{x:Static locdata:WorkflowButtonState.Register}">
<Setter Property="Content" Value="Register"/>
</DataTrigger>
<DataTrigger Binding="{Binding Path=ButtonState}" Value="{x:Static locdata:WorkflowButtonState.Submit}">
<Setter Property="Content" Value="Submit"/>
</DataTrigger>
</Style.Triggers>
</Style>
</Label.Style>初始化代码块
private void InitRegister()
{
ButtonState = WorkflowButtonState.Register;
ClickCommand = new DelegateCommand(RegisterClicked);
}
private void InitSubmit()
{
ButtonState = WorkflowButtonState.Submit;
ClickCommand = new DelegateCommand(SubmitClicked);
}
private void Reset()
{
ClickCommand = null;
ButtonState = WorkflowButtonState.Default;
}调试模式清楚地显示ClickCommand执行方法是SubmitClicked,但是RegisterClicked事件仍然会触发。这仅在因为用户以前没有在工作站上登录而首先发生注册进程时才会发生。
由于设置EventHandler = null没有帮助,所以复制-=行为需要什么?
更新
到目前为止,在我的应用程序中,ICommand的使用只是一个单一的用途。正如Andy的回答所指出的,它应该被视为一项财产,并引发财产变更事件。
更新后的ICommand声明,正如我多次对属性所做的那样,所有需要更改的内容都已更改。
private ICommand _clickCommand;
public ICommand ClickCommand { get => _clickCommand; set { _clickCommand = value; OnPropertyChanged(); } }发布于 2020-06-26 09:07:52
这里有两件事要考虑:
你通知财产变更。
一些示例标记:
<Window.DataContext>
<local:MainWindowViewModel/>
</Window.DataContext>
<StackPanel>
<Button Command="{Binding TestCommand}" Content="Test"/>
<Button Command="{Binding ChangeCommand}" Content="Change Test Command"/>
</StackPanel>
</Window>有一个测试命令,它从一个命令开始,然后单击change test命令按钮,它将更改为另一个命令。
我的视图模型:
public class MainWindowViewModel : BindableBase
{
private DelegateCommand testCommand;
public DelegateCommand TestCommand
{
get => testCommand;
set { testCommand = value; RaisePropertyChanged(); }
}
public DelegateCommand ChangeCommand { get; set; }
public MainWindowViewModel()
{
TestCommand = new DelegateCommand(() => { MessageBox.Show("Original Command"); });
ChangeCommand = new DelegateCommand(() =>
{
TestCommand = new DelegateCommand(() => { MessageBox.Show("Replacement is used"); });
});
}
}当调用changecommand时,test命令的委托- testcommand被替换为一个新命令。
和。
调用已更改的属性。
它告诉UI去获取这个新命令。
如果然后删除从TestCommand中更改的引发属性:
public DelegateCommand TestCommand
{
get => testCommand;
set { testCommand = value; }
}单击“更改”按钮,然后单击“我的测试”按钮,我将得到原始命令“运行”。这就是你所看到的问题。因为您的命令看起来是:
public ICommand ClickCommand { get; set; }没有引起财产的变化。
注意:
如果我的变化是:
ChangeCommand = new DelegateCommand(() =>
{
TestCommand = null;
});然后单击“更改”按钮,单击“测试”按钮,就不会发生任何事情。它的命令现在为null。
https://stackoverflow.com/questions/62583631
复制相似问题