使用MVVM在WPF中绑定命令

问题描述:

我在学习MVVMWPF。我在我的项目中有一个xaml文件,并且在后面的代码中有一个简单的单击事件处理程序。使用MVVM在WPF中绑定命令

现在我想在MVVM中做同样的事情。我阅读了许多文章,并阅读了很多答案。但仍然无法做到这一点。

谁能请举一个简单的例子,其中一个按钮点击事件在MVVM完成。

编辑提前

<Window x:Class="WhiteBalance.BaseCalWindow" 
     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
     xmlns:uc="clr-namespace:NumberUpDownControl;assembly=NumberUpDownControl" 
     xmlns:viewn="clr-namespace:WhiteBalance.ViewModels" 
     Title="RefImgSettingWindow" Height="900" Width="1000" ResizeMode="NoResize" 
     BorderThickness="4"> 
    <Window.Resources> 
     <viewn:DashBoardViewModel x:Key="demokey"></viewn:DashBoardViewModel> 
    </Window.Resources> 
    <Grid x:Name="gdParent" DataContext="{StaticResource demokey}"> 
     <Grid.ColumnDefinitions> 
      <ColumnDefinition Width="490" /> 
      <ColumnDefinition Width="488*" /> 
     </Grid.ColumnDefinitions> 
     <Grid.RowDefinitions> 
      <RowDefinition Height="300" /> 
      <RowDefinition Height="300" /> 
      <RowDefinition Height="*" /> 
     </Grid.RowDefinitions> 
     <StackPanel Grid.Row="0" Grid.Column="0"> 
      <Label Content="{Binding Path=NAME,Mode=TwoWay}" Height="28" Name="lblTest" /> 
      <Button Content="Capture" Height="23" Name="btnCapture" Width="75" Command="{Binding Path=SaveCommand}" 
          Canvas.Left="94" Canvas.Top="254" /> 

     </StackPanel> 
    </Grid> 
</Window> 

namespace WhiteBalance.ViewModels 
{ 
    public class DashBoardViewModel: ObservableObject 
    { 
     private string _name = "dsqdasd"; 

     public string NAME 
     { 
      get { return _name; } 
      set { _name = value; } 
     } 

     public ICommand SaveCommand 
     { 
      get; 
      set; 
     } 

     private bool CanExecuteSaveCommand() 
     { 
      return true; // !string.IsNullOrEmpty(LastName); 
     } 

     private void CreateSaveCommand() 
     { 
      SaveCommand = new RelayCommand(SaveExecute, CanExecuteSaveCommand); 
     } 

     public void SaveExecute() 
     { 
      //Person.Save(_newPerson); 
      NAME = "Changed Name"; 
     } 

     public DashBoardViewModel() 
     { 
      //objModel.TestText = "This will change"; 
      NAME = "TestName"; 
     } 
    } 
} 

感谢。

+0

您是否使用任何MVVM框架?你有什么尝试? – 2013-05-01 08:25:25

+0

使用MVVM框架是强制性的吗?我不知道有任何框架。我唯一得到的是我需要使用ICommand,但是如何使用这个以及ViewModel需要哪些更改,我不知道。 – Narendra 2013-05-01 08:28:40

+2

不,但它有助于很多,我建议MVVM光http://www.galasoft.ch/mvvm/ – 2013-05-01 08:30:53

您可以将按钮的Command属性绑定到任何返回ICommand的属性。 Prism实现(它here is a knock-off)叫DelegateCommand一个很好的方便的命令,这是非常容易使用:

public ICommand MyButtonClickCommand 
{ 
    get { return new DelegateCommand<object>(FuncToCall, FuncToEvaluate); } 
} 

private void FuncToCall(object context) 
{ 
    //this is called when the button is clicked 
} 

private bool FuncToEvaluate(object context) 
{ 
    //this is called to evaluate whether FuncToCall can be called 
    //for example you can return true or false based on some validation logic 
    return true; 
} 



<Button x:Name="myButton" Command="{Binding MyButtonClickCommand}" /> 

CodeProject上的例子How to use Commands in WPF有代码,您可以轻松地合作,通过一个非常类似的例子。前面的堆栈溢出问题有一个使用静态绑定的RoutedCommands的示例:How to bind Close command to a buttonHow to bind WPF button to a command in ViewModelBase?有一个稍微高级的示例。

+0

谢谢@slugster。 DelegateCommand是一个系统定义的类,还是我需要创建它?我正在检查您提供的链接。 – Narendra 2013-05-01 08:34:01

+0

@Narendra它是在Prism库中定义的,你只需要引用它们,或者查看一下这个knock-off版本的链接。 – slugster 2013-05-01 08:41:02

+0

我添加了最近的更改问题。您能否告诉我们为什么它没有调用所需的功能? – Narendra 2013-05-01 09:43:26