ホームページ > バックエンド開発 > C++ > MVVM ViewModel で UI イベントをコマンドにバインドするにはどうすればよいですか?

MVVM ViewModel で UI イベントをコマンドにバインドするにはどうすればよいですか?

Susan Sarandon
リリース: 2025-01-12 22:28:44
オリジナル
799 人が閲覧しました

How to Bind UI Events to Commands in an MVVM ViewModel?

ViewModel のコマンドに UI イベントをバインドする: MVVM パースペクティブ

MVVM (Model-View-ViewModel) アーキテクチャを採用する場合、共通の課題は、UI イベントをコードビハインドから切り離し、ViewModel に移動して懸念事項の分離を改善する方法です。ここでイベント バインディングが役に立ちます。

イベント バインディングについて

伝統的に、UI イベントはコードビハインドで直接処理されるため、保守が困難なスパゲッティ コードが生成されることがよくあります。イベント バインディングを使用すると、UI イベントを ViewModel 内のコマンドにバインドできるようになり、UI のプレゼンテーションをイベント処理ロジックから効果的に切り離すことができます。

イベントバインディングを実装する

WPF 環境では、System.Windows.Interactivity 名前空間の EventTrigger クラスと InvokeCommandAction クラスを使用してイベント バインディングを実装できます。次の例を考えてみましょう:

<code class="language-xml"><ListBox ...>
  <i:Interaction.Triggers>
    <i:EventTrigger EventName="SelectionChanged">
      <i:InvokeCommandAction Command="{Binding SelectedItemChangedCommand}" />
    </i:EventTrigger>
  </i:Interaction.Triggers>
</ListBox></code>
ログイン後にコピー

ListBox の SelectionChanged イベントに EventTrigger をアタッチすることにより、ViewModel で SelectedItemChangedCommand へのバインディングを作成します。

ViewModel の実装

ViewModel で、SelectedItemChangedCommand プロパティとその実装を定義します。

<code class="language-csharp">public ICommand SelectedItemChangedCommand { get; private set; }

public MyAppViewModel()
{
    // ...
    SelectedItemChangedCommand = new RelayCommand((param) => { /* 在此处处理选择更改逻辑 */ });
}</code>
ログイン後にコピー

参照 System.Windows.Interactivity

EventTrigger クラスと InvokeCommandAction クラスを使用するには、System.Windows.Interactivity.dll を参照する必要があります。これを行うには、Visual Studio でプロジェクトを右クリックし、[参照の追加] を選択して、[拡張機能] タブを参照します。

i 名前空間プレフィックス

XML バインディングの i 名前空間プレフィックスは、「System.Windows.Interactivity」の略称です。プロジェクトでアセンブリを参照する場合は、完全な名前空間「clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity」を必ず含めてください。

この方法でイベント バインディングを実装することで、UI イベントをコードビハインドから分離することができ、より柔軟でテストしやすいコードを作成できるようになります。このアプローチは MVVM アーキテクチャの原則に準拠しており、クリーンなコード編成と保守性を促進します。

以上がMVVM ViewModel で UI イベントをコマンドにバインドするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート