WPF Label控件在数据绑定Content属性变化触发TargetUpdated事件简单实现类似TextChanged 事件效果

 

本以为Label也有TextChanged 事件,但在使用的时候却没找到,网友说LabelContent属性改变肯定是使用赋值操作,赋值的时候就可以对其进行相应的操作所以不需TextChanged 事件。

MSDN查了一下,TextChanged 事件TextBoxBase类中;而LabelTextBox的继承关系如下:

Label

System.Object
  System.Windows.Threading.DispatcherObject
    System.Windows.DependencyObject
      System.Windows.Media.Visual
        System.Windows.UIElement
          System.Windows.FrameworkElement
            System.Windows.Controls.Control
             System.Windows.Controls.ContentControl
                System.Windows.Controls.Label

 

TextBox:

System.Object
  System.Windows.Threading.DispatcherObject
    System.Windows.DependencyObject
      System.Windows.Media.Visual
        System.Windows.UIElement
          System.Windows.FrameworkElement
            System.Windows.Controls.Control
             System.Windows.Controls.Primitives.TextBoxBase
                System.Windows.Controls.TextBox
                  System.Windows.Controls.Primitives.DatePickerTextBox
                  System.Windows.Controls.Ribbon.RibbonTextBox

 

从上面红色就可以看出继承路径的不同,所以Label没有TextChanged 事件

如何实现修改LabelContent属性自动执行类似TextChanged 事件呢?

这里实现了一种使用数据绑定的方式,借助TargetUpdated事件进行类似TextChanged 事件

 

具体代码供参考:

项目中使用工厂模式设置好了数据绑定:

 if (element is UIElement)

                        {

                            UIElement uiElement = element as UIElement;

                            Binding binding = new Binding();

                            binding.Mode = BindingMode.TwoWay;

                            binding.Path = new PropertyPath(item.Value.DataPath);

                            binding.Source = item.Value.DataSource;

                            binding.NotifyOnTargetUpdated = true;

                            DependencyProperty dependProperty = GetDependencyProperty(item.Value.BindingProperty);

                            BindingOperations.SetBinding(uiElement, dependProperty, binding);

                        }

想使用TargetUpdated事件binding.NotifyOnTargetUpdated 属性必须为True;

然后为Label注册 TargetUpdated 事件:

label.TargetUpdated += Label_DataContextChanged;

 

 

至此就可以简单实现类似TextChanged 事件

 

不对之处望指教!

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这里是一段在MVVM模式下使用RelativeSource绑定控件数据源,并且在点击复选框时触发控件事件WPF代码。 首先,我们需要在父控件中定义一个事件,并在VM中绑定事件。我们可以使用`EventToCommand`来实现这一点,它是Galasoft.MvvmLight库中提供的一个类。 在XAML中,我们可以这样定义父控件和复选框: ```xml <UserControl x:Class="MyApp.MyParentControl" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:i="http://schemas.microsoft.com/expression/2010/interactivity" xmlns:command="http://www.galasoft.ch/mvvmlight"> <Grid> <!-- 父控件数据源 --> <Grid.DataContext> <local:MyParentViewModel /> </Grid.DataContext> <!-- 复选框 --> <CheckBox Content="Click me!" IsChecked="{Binding IsChecked, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type UserControl}}}" Margin="10" VerticalAlignment="Center"> <i:Interaction.Triggers> <i:EventTrigger EventName="Click"> <command:EventToCommand Command="{Binding DataContext.MyParentControlClickedCommand, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type UserControl}}}" PassEventArgsToCommand="True" /> </i:EventTrigger> </i:Interaction.Triggers> </CheckBox> </Grid> </UserControl> ``` 在这里,我们使用了`RelativeSource`来绑定复选框的`IsChecked`属性到父控件数据源上。同时,我们也使用了`EventToCommand`来绑定复选框的`Click`事件到父控件的`MyParentControlClickedCommand`命令上,并且通过`PassEventArgsToCommand`属性来传递事件参数。 然后,在VM中定义`MyParentControlClickedCommand`命令和`MyParentControlClicked`事件: ```csharp public class MyParentViewModel : ViewModelBase { public RelayCommand<RoutedEventArgs> MyParentControlClickedCommand { get; private set; } public MyParentViewModel() { MyParentControlClickedCommand = new RelayCommand<RoutedEventArgs>(MyParentControlClicked); } public event EventHandler<MyEventArgs> MyParentControlClicked; private void MyParentControlClicked(RoutedEventArgs e) { // 触发事件 MyParentControlClicked?.Invoke(this, new MyEventArgs()); } } public class MyEventArgs : EventArgs { // 添加事件参数 } ``` 最后,在父控件的代码中订阅事件: ```csharp public partial class MyParentControl : UserControl { public MyParentControl() { InitializeComponent(); // 订阅事件 var viewModel = (MyParentViewModel)DataContext; viewModel.MyParentControlClicked += MyParentControl_MyParentControlClicked; } private void MyParentControl_MyParentControlClicked(object sender, MyEventArgs e) { // 处理事件 } } ``` 这样,当我们点击复选框时,就会触发控件的`MyParentControlClicked`事件了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值