WPF 绑定binding都有哪些事件

在WPF中,源属性(Source Property)指的是提供数据的属性,通常是数据模型或者其他控件的属性,而目标属性(Target Property)则是数据绑定的目标,通常是绑定到控件的属性,例如TextBlock的Text属性。数据绑定将源属性的值自动更新到目标属性中。

主要包含以下几个事件:

  1. UpdateSourceTrigger:用于控制数据绑定如何更新源数据的事件
  • PropertyChanged:每当目标属性的值更改时,将立即更新源属性。
  • LostFocus:当目标元素失去焦点时,更新源属性。
  • Explicit:只有在调用BindingExpression.UpdateSource方法时才会更新源属性。
  • Default:与绑定目标和属性的数据类型有关,通常是LostFocus或PropertyChanged事件。
  • Explicit和LostFocus是最常见的UpdateSourceTrigger事件,而PropertyChanged是最常用的默认事件。
  1. NotifyOnTargetUpdated:指定当绑定目标发生更改时是否引发TargetUpdated事件。
  • 如果将此属性设置为true,则当目标属性更改时,将在绑定源上引发TargetUpdated事件(可在该事件中通知绑定源进行相应的更改)。
  • 需要注意的是,如果在绑定中使用了Mode属性,并且Mode属性的值为TwoWay,则NotifyOnTargetUpdated属性将被忽略。这是因为在TwoWay模式下,更改源或目标都会引发另一个方向上的更新。
  1. NotifyOnSourceUpdated:指定当绑定源发生更改时是否引发SourceUpdated事件。
  • 如果将此属性设置为true,则当源属性更改时,将在绑定目标上引发SourceUpdated事件(可在该事件中通知绑定目标进行相应的更改)。
  • 需要注意的是,如果在绑定中使用了Mode属性,并且Mode属性的值为TwoWay,则NotifyOnSourceUpdated和属性将被忽略。这是因为在TwoWay模式下,更改源或目标都会引发另一个方向上的更新。
  1. ValidatesOnDataErrors:是一个可选的事件,它允许开发人员在数据绑定时验证数据,是用于指定是否启用数据验证错误。
  • 当设置了该事件时,WPF会在数据源中实现IDataErrorInfo接口的类中的Error属性发生更改时,自动调用该事件。开发人员可以使用该事件来检测数据绑定中的错误,并采取适当的措施,例如禁用按钮或显示错误消息。如果开发人员不设置ValidatesOnDataErrors事件,则WPF将不会在数据绑定中自动执行数据验证。如何利用 IDataErrorInfo 实现数据校验 - LXLR - 博客园 (cnblogs.com)
  • 当数据验证失败时,绑定会将错误信息存储在Binding对象的Validation.Errors属性中。但是,这些错误信息不会自动显示在UI元素中,需要使用NotifyOnValidationError属性来实现。
  1. NotifyOnValidationError:用于指定当数据验证失败时是否触发属性更改事件。
  • 如果设置为True,则当数据验证失败时,属性更改事件将被触发,这意味着可以在代码中捕获和处理该事件。如果设置为False,则属性更改事件将不会在数据验证失败时触发。
  • 当NotifyOnValidationError属性设置为True时,如果绑定数据时发生验证错误,Binding会引发一个Validation.Error事件,该事件可以被UI元素捕获并显示错误信息。
相关推荐
m0_748229995 分钟前
Vue3高效学习路线全攻略
前端·javascript·vue.js
谢尔登17 分钟前
React架构演变
前端·react.js·架构
流水线上的指令侠19 分钟前
C# 实战:从 0 到 1 搭建基于 NUnit + FlaUI 的 WPF UI 自动化测试项目
功能测试·ui·c#·自动化·wpf·visual studio
木辰風21 分钟前
vue在IE浏览器下父页面向子页面传输对象时数据丢失
前端·javascript·html
小雨青年29 分钟前
Cursor 项目实战:AI播客策划助手(四)—— 产品发布与交付收尾
前端·人工智能
晚霞的不甘1 小时前
Flutter for OpenHarmony《淘淘购物》主页点击跳转功能详解:从 UI 响应到页面导航的完整实现
前端·flutter·ui·搜索引擎·前端框架·交互
cooldream20091 小时前
前端技术架构详解:Vue 3 + TypeScript + Vite 在具身 AI 系统中的实践
前端·架构·typescript
迟_1 小时前
CSS-实现图片靠右
前端·css
weixin_395448911 小时前
下位机&yolov11输出
java·服务器·前端
秋秋秋秋秋雨1 小时前
基于若依的vue3+springboot3基础架构项目,前端优化
前端