我正在尝试使用自定义delegate command
但是,自动RaiseCanExecuteChanged无法正常工作。 使用CommandManagerHelper是否很好(每当应用程序处于焦点时,它会针对每个命令引发canexecute更改? 或者我必须使用标准的RelayCommand并自己提高canexecutechanged?
由于
答案 0 :(得分:1)
RaiseCanExecuteChanged事件在自动模式下无法正常运行。因此,每个UI交互都有这样的实现,以刷新针对RequerySuggested事件的canExecute处理程序。代码如下(请记住,ICommand的这种实现不是性能有效,但就像魅力一样):
public class Command<TArgs> : ICommand
{
public Command(Action<TArgs> exDelegate)
{
_exDelegate = exDelegate;
}
public Command(Action<TArgs> exDelegate, Func<TArgs, bool> canDelegate)
{
_exDelegate = exDelegate;
_canDelegate = canDelegate;
}
protected Action<TArgs> _exDelegate;
protected Func<TArgs, bool> _canDelegate;
#region ICommand Members
public bool CanExecute(TArgs parameter)
{
if (_canDelegate == null)
return true;
return _canDelegate(parameter);
}
public void Execute(TArgs parameter)
{
if (_exDelegate != null)
{
_exDelegate(parameter);
}
}
public event EventHandler CanExecuteChanged
{
add { CommandManager.RequerySuggested += value; }
remove { CommandManager.RequerySuggested -= value; }
}
bool ICommand.CanExecute(object parameter)
{
if (parameter != null)
{
var parameterType = parameter.GetType();
if (parameterType.FullName.Equals("MS.Internal.NamedObject"))
return false;
}
return CanExecute((TArgs)parameter);
}
void ICommand.Execute(object parameter)
{
Execute((TArgs)parameter);
}
#endregion
}
答案 1 :(得分:0)
最佳解决方案是使用RelayCommand并手动引发CanExecuteChanged。 另一种解决方案无法正常工作。