UpdateSourceTrigger Property in WPF Binding_.NET_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > .NET > UpdateSourceTrigger Property in WPF Binding

UpdateSourceTrigger Property in WPF Binding

 2013/8/1 16:11:15  KissFu  博客园  我要评论(0)
  • 摘要:介绍这篇文章我将介绍在WPF和Silverlight中更新绑定源的概念。正如您所知道的,当我们用TwoWay的模式绑定时,任何在目标控件上发生的变化都会影响绑定源的值。请注意只是在用TwoWay绑定的时候,而不是默认的绑定模式OneWay或者OneTime。现在,问题是当更新源数据时,由于目标控件的数据发生的变化。实际上有三个方法可以实现。Default:由不同控件控制.例如TextBox,当LostFocus事件触发时,目标绑定发生变化.PropertyChanged
  • 标签:

介绍

这篇文章我将介绍在WPF和Silverlight中更新绑定源的概念。正如您所知道的,当我们用TwoWay的模式绑定时,任何在目标控件上发生的变化都会影响绑定源的值。

请注意只是在用TwoWay绑定的时候,而不是默认的绑定模式OneWay或者OneTime。

现在,问题是当更新源数据时,由于目标控件的数据发生的变化。实际上有三个方法可以实现。

    • Default: 由不同控件控制. 例如 TextBox, 当 LostFocus 事件触发时,目标绑定发生变化.
    • PropertyChanged: 意味着当目标控件值发生变化时,源数据立马更新.例如, TextBox是目标绑定,当输入字符时, 源数据也发生变化. 着就意味着当你输入字符创的时候,TextBox的数据Text也在改变.
    • Explicit: 当UpdateSourceTrigger 设置为 Explicit, 数据源不会自动更新,只有在后代码里面显示的触发。 

 

针对这些方法我写啦一些代码帮助你们更好的理解他们.我们首先从 default 开始. 看下面的代码块:

 1 <Border BorderThickness="2" Margin="0 20 0 0" BorderBrush="Brown" CornerRadius="5">
 2     <StackPanel>
 3         <TextBox x:Name="textInput2" Margin="5" />
 4         <TextBox x:Name="txtOutput2" Margin="5"
 5                          Text="{Binding Text,
 6                                 ElementName=textInput2,
 7                                 UpdateSourceTrigger=Default,
 8                                 Mode=TwoWay}"/>
 9     </StackPanel>
10 </Border>

 

这里有一个Border元素里面有一个StackPanel里面包含两个TextBox.第二个TextBox的Text属性绑定啦第一个TextBox的属性Text.在所有的例子里面实际上还有一些代码. 这个绑定的Mode 设置为 TwoWay 因为我们想更新源数据无论目标发生变化的时候. 最后, 绑定的属性UpdateSourceTrigger被设置为 Default. 这就意味着当第二个TextBox的绑定目标丢失焦点或者触发LostFocus 事件时,第一个TextBox的属性Text绑定的源数据会被更新。

第二个例子是设置 UpdateSourceTrigger 为PropertyChanged.

 1 <Border BorderThickness="2" BorderBrush="Brown" CornerRadius="5">
 2     <StackPanel>
 3         <TextBox x:Name="textInput1" Margin="5" />
 4         <TextBox x:Name="txtOutput1" Margin="5" 
 5                          Text="{Binding Text,
 6                                 ElementName=textInput1,
 7                                 UpdateSourceTrigger=PropertyChanged,
 8                                 Mode=TwoWay}"/>
 9     </StackPanel>
10 </Border>

 

这个代码块和第二个相比唯一不同的是 UpdateSourceTrigger 被设置为 PropertyChanged. 正如这个名字暗示的, 这就意味着无论何时第二个TextBox的Text属性发生变化时,第一个TextBox的属性Text立马被更新。

最后,我们最后的例子是将属性 UpdateSourceTrigger 设置为 Explicit.

 1 <Border BorderThickness="2" Margin="0 20 0 0" BorderBrush="Brown" CornerRadius="5">
 2     <StackPanel>
 3         <TextBox x:Name="textInput3" Margin="5" />
 4         <TextBox x:Name="txtOutput3" Margin="5" 
 5                          Text="{Binding Text,
 6                                 ElementName=textInput3,
 7                                 UpdateSourceTrigger=Explicit,
 8                                 Mode=TwoWay}"/>
 9         <Button Content="Save" Click="Button_Click"/>
10     </StackPanel>
11 </Border>

不同的东西在这段代码是UpdateSourceTrigger设置为Explicit。正如我们前面所说,这意味着更新过程不会发生,除非你做到明确操作。这个Button 被声明在第二个TextBox后面负责做明确操作。正如你可能已经注意到,有一个EventHandler对它的点击事件Clickevent,,下面几行代码都写在那EventHandler里。

1 private void Button_Click(object sender, RoutedEventArgs e)
2 {
3     BindingExpression be = txtOutput3.GetBindingExpression(TextBox.TextProperty);
4     be.UpdateSource();
5 }

BindingExpression类声明一个实例。在那之后,txtOutput3获取TextBox.TextProperty的绑定表达式放在那个实例里。最后,UpdateSource方法的是被称为明确的更新绑定源。

 代码下载地址:http://www.codeproject.com/Articles/507883/UpdateSourceTrigger-Property-in-WPF-Binding

  • 相关文章
发表评论
用户名: 匿名