WPF 控件CommandParameter绑定多个参数

文章介绍了如何在WPF中通过创建一个继承自IMultiValueConverter的类,实现CommandParameter绑定多个参数的功能。在XAML中添加资源并使用MultiBinding,然后在ViewModel中解析接收到的参数,以此来接收和处理来自两个不同控件的值。
摘要由CSDN通过智能技术生成

WPF 控件CommandParameter绑定多个参数

新建一个类,继承IMultiValueConverter

public class MultiBindingConverter : IMultiValueConverter
    {
        public object Convert(object[] values, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            return values.Clone();
        }

        public object[] ConvertBack(object value, Type[] targetTypes, object parameter, System.Globalization.CultureInfo culture)
        {
            throw new NotImplementedException();
        }
    }

xaml中添加引用

xmlns:{wpfbd}="clr-namespace:{新建类所在的命名空间}"
添加完重新生成一次

添加资源

<wpfbd:MultiBindingConverter x:Key="MultiConverter"></wpfbd:MultiBindingConverter>

为控件添加参数

<Button.CommandParameter>
    <MultiBinding Converter="{ StaticResource MultiConverter}">
   	    <Binding ElementName="{控件名称}"></Binding>
    	<Binding ElementName="{控件名称}"></Binding>
    </MultiBinding>                        
</Button.CommandParameter>

在View Model中使用多个参数

_commandStart.DoExecute = new Action<object>(obj =>
  {
         var objarr = (object[])obj;
         //接收第一个控件
         {控件类型} name= (objarr[0] as {控件类型});
         //接收第二个控件
         {控件类型} name= (objarr[1] as {控件类型});
  }
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你可以通过在用户控件中定义多个按钮,并将每个按钮的命令属性绑定到不同的命令对象上来实现多个按钮命令的功能。以下是一个简单的示例: 1. 首先,在用户控件的 XAML 文件中定义多个按钮,并为每个按钮设置命令属性和命令参数属性: ```xml <UserControl x:Class="MyUserControl"> <StackPanel> <Button Content="Save" Command="{Binding SaveCommand}" CommandParameter="parameter1"/> <Button Content="Cancel" Command="{Binding CancelCommand}" CommandParameter="parameter2"/> <Button Content="Delete" Command="{Binding DeleteCommand}" CommandParameter="parameter3"/> </StackPanel> </UserControl> ``` 2. 然后,在用户控件的代码文件中定义多个命令对象,并将它们绑定到对应的按钮上: ```csharp public partial class MyUserControl : UserControl { public ICommand SaveCommand { get; set; } public ICommand CancelCommand { get; set; } public ICommand DeleteCommand { get; set; } public MyUserControl() { InitializeComponent(); SaveCommand = new RelayCommand(Save); CancelCommand = new RelayCommand(Cancel); DeleteCommand = new RelayCommand(Delete); DataContext = this; } private void Save(object parameter) { // Save command logic here } private void Cancel(object parameter) { // Cancel command logic here } private void Delete(object parameter) { // Delete command logic here } } ``` 3. 最后,在使用用户控件的地方,将每个命令对象分别设置为对应的命令处理程序即可: ```xml <Window x:Class="MyWindow"> <Grid> <local:MyUserControl SaveCommand="{Binding SaveCommand}" CancelCommand="{Binding CancelCommand}" DeleteCommand="{Binding DeleteCommand}"/> </Grid> </Window> ``` 这样,你就可以在用户控件中实现多个按钮命令的功能了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值