2 つのウィンドウを持つ単純な WPF アプリケーションがあり、MVVM モデルを使用するように変更したいと考えています。
ボタンとメッセージボックスで簡単なバインディングを作成し始めましたが、うまくいきません。コマンドの Execute 関数が呼び出されることはありませんが、出力ウィンドウにバインド エラーが表示されません。
これらを使用してバインディングをデバッグおよびトレースします: http://www.beacosta.com/blog/?p=52 壊れた WPF データ バインディングを検出するには?
トレースは次のとおりです。
System.Windows.Data Warning: 54 : Created BindingExpression (hash=8493835) for Binding (hash=45202970)
System.Windows.Data Warning: 56 : Path: 'LoginCommand'
System.Windows.Data Warning: 58 : BindingExpression (hash=8493835): Default mode resolved to OneWay
System.Windows.Data Warning: 59 : BindingExpression (hash=8493835): Default update trigger resolved to PropertyChanged
System.Windows.Data Warning: 60 : BindingExpression (hash=8493835): Attach to System.Windows.Controls.Button.Command (hash=17604022)
System.Windows.Data Warning: 65 : BindingExpression (hash=8493835): Resolving source
System.Windows.Data Warning: 68 : BindingExpression (hash=8493835): Found data context element: Button (hash=17604022) (OK)
System.Windows.Data Warning: 76 : BindingExpression (hash=8493835): Activate with root item LoginViewModel (hash=47369058)
System.Windows.Data Warning: 106 : BindingExpression (hash=8493835): At level 0 - for LoginViewModel.LoginCommand found accessor ReflectPropertyDescriptor(LoginCommand)
System.Windows.Data Warning: 102 : BindingExpression (hash=8493835): Replace item at level 0 with LoginViewModel (hash=47369058), using accessor ReflectPropertyDescriptor(LoginCommand)
System.Windows.Data Warning: 99 : BindingExpression (hash=8493835): GetValue at level 0 from LoginViewModel (hash=47369058) using ReflectPropertyDescriptor(LoginCommand): RelayCommand (hash=32714449)
System.Windows.Data Warning: 78 : BindingExpression (hash=8493835): TransferValue - got raw value RelayCommand (hash=32714449)
System.Windows.Data Warning: 82 : BindingExpression (hash=8493835): TransferValue - implicit converter produced <null>
System.Windows.Data Warning: 87 : BindingExpression (hash=8493835): TransferValue - using final value <null>
私のコードの関連部分は以下の通りです。
Loginview.xaml:
<Window.DataContext>
<local:LoginViewModel/>
</Window.DataContext>
...
<Button Content="Login"
Command="{Binding LoginCommand, diagnostics:PresentationTraceSources.TraceLevel=High}"
CommandParameter="Hello">
LoginViewModel.cs:
class LoginViewModel
{
private RelayCommand m_LoginCommand;
public RelayCommand LoginCommand
{
get
{
if (m_LoginCommand == null)
{
m_LoginCommand = new RelayCommand(param => this.Login(param));
}
return m_LoginCommand;
}
}
public void Login(object obj)
{
MessageBox.Show(obj.ToString());
}
}
RelayCommand.cs:
class RelayCommand
{
private Action<object> _execute;
public RelayCommand(Action<object> execute)
{
_execute = execute;
}
#region ICommand Members
public bool CanExecute(object parameter)
{
return true;
}
public event EventHandler CanExecuteChanged;
public void Execute(object parameter)
{
// breakpoint; code execution never reaches here
_execute(parameter);
}
#endregion
}