首页 > 代码库 > 学习WPF——元素绑定
学习WPF——元素绑定
概念
从源对象提取一些信息,并用这些信息设置目标对象的属性
示例
数据绑定表达式使用XAML的标记扩展(因此具有花括号)(参见:)
这里创建了一个System.Windows.Data.Binding对象,所以绑定表达式以单词binding开头
在本例中只设置了Binding对象的两个属性ElementName和Path属性
ElementName | 指定源元素 |
Path | 指定源元素中的属性 |
Mode | OneWay: 当源属性变化时,更新目标属性 TwoWay: 当源属性变化时,更新目标属性,并且,当目标属性变化时,更新源属性 OneTime: 最初根据源属性值设置目标属性,其后的所有改变都会被忽略 OneWayToSource: 当目标属性变化时,更新源属性,源属性变化时,目标属性不变 Default: 根据目标属性的设置而定 |
UpdateSourceTrigger | 如果我们把一个属性的值绑定到一个文本框的Text上,那么只有当这个文本框失去焦点时才会更新目标属性的值;如果你想实时更新目标属性的值该如何处理呢?那么这时就要设置UpdateSourceTrigger属性了,这个属性有一下几种可能的情况 PropertyChange: 当目标属性发声变化时立即更新 LostFocus: 当目标属性发生变化,并且目标失去焦点时更新 Explicit: 除非调用BindingExpression.UpdateSource()方法,否则无法更新源 Default: 根据目标属性的设置来确定更新行为,大多数元素都是PropertyChange设置,但TextBox.Text属性是LostFocus设置 |
Delay | 有的时候需要延迟一段时间再更新目标属性的值,此时需要设置Delay属性,单位是毫秒 |
Source | 绑定到非元素对象;与ElementName互斥 该属性指向源对象的引用(就是提供数据的对象) 以下代码可以绑定到已经存在的对象 以下代码可以绑定到已经存在的资源 |
RelativeSource | 绑定到非元素对象;与ElementName互斥 Self: 表达式绑定到同一元素的另一属性上 FindAncestor: 表达式绑定到父元素 PreviousData: 绑定到数据列表中的前一个数据项,应用在数据列表元素中 TemplateParent: 绑定到应用模版的元素,在模版内这种设置才生效 |
说明
除了绑定到元素的属性,还可以绑定到元素的属性的属性或者存在索引器的属性 比如: MyElement.Property.OtherProperty MyElement.Property[2] |
当绑定到格式不正确的元素属性上时,WPF并不会因此而编译不通过 |
双向绑定比单向绑定开销更大,OneTime绑定比双向绑定和单向绑定的开销都小 |
尽量使用明确的绑定模式,而不要使用Default绑定模式 |
源属性改变,通知到目标属性后,目标属性还可以作为源属性,通知下一个目标属性,这就是多绑定 |
使用代码创建绑定
在上面的示例中完全可以使用C#代码创建绑定
代码如下
使用代码删除绑定如果像通过代码删除某一个元素的绑定,可以通过下面两种方式完成
使用代码检索绑定
可以使用如下方式获取一个元素的绑定对象
使用DataContext绑定
可以先对父元素设置DataContext属性,然后在子元素中就可以轻松的使用父元素设置的DataContext所指向的对象了
修改记录
2015-1-5:完成一部分内容
参考资料
《Pro WPF 4.5 in C# 4th Edition》
学习WPF——元素绑定
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。