使用MVVM在WPF中绑定命令
问题描述:
我在学习MVVM和WPF。我在我的项目中有一个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";
}
}
}
感谢。
答
您可以将按钮的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 button和How to bind WPF button to a command in ViewModelBase?有一个稍微高级的示例。
您是否使用任何MVVM框架?你有什么尝试? – 2013-05-01 08:25:25
使用MVVM框架是强制性的吗?我不知道有任何框架。我唯一得到的是我需要使用ICommand,但是如何使用这个以及ViewModel需要哪些更改,我不知道。 – Narendra 2013-05-01 08:28:40
不,但它有助于很多,我建议MVVM光http://www.galasoft.ch/mvvm/ – 2013-05-01 08:30:53